>백엔드 개발 >PHP 튜토리얼 >계층적 배열 목록에서 트리 구조를 효율적으로 구축하는 방법은 무엇입니까?

계층적 배열 목록에서 트리 구조를 효율적으로 구축하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-11-29 11:01:10776검색

How to Efficiently Build a Tree Structure from a Hierarchical Array List?

배열 목록에서 트리 구조 구축

계층 관계가 있는 항목의 배열 목록이 주어지면 어떻게 효율적으로 이를 트리 구조로 변환할 수 있습니까? 중첩 트리 구조?

해결책:

복잡한 데이터베이스 최적화를 사용하지 않고 이 변환을 수행하려면 재귀 함수를 사용할 수 있습니다.

$arr = array(
  array('id' => 100, 'parentid' => 0, 'name' => 'a'),
  array('id' => 101, 'parentid' => 100, 'name' => 'a'),
  array('id' => 102, 'parentid' => 101, 'name' => 'a'),
  array('id' => 103, 'parentid' => 101, 'name' => 'a'),
);

$new = array();
foreach ($arr as $a) {
    $new[$a['parentid']][] = $a;
}
$tree = createTree($new, array($arr[0]));
print_r($tree);

function createTree(&$list, $parent){
    $tree = array();
    foreach ($parent as $k => $l){
        if(isset($list[$l['id']])){
            $l['children'] = createTree($list, $list[$l['id']]);
        }
        $tree[] = $l;
    } 
    return $tree;
}

이 코드 항목 간의 상위-하위 관계를 나타내는 중첩된 계층 구조로 항목을 정렬합니다. 결과 트리 구조는 print_r을 사용하여 인쇄할 수 있습니다.

재귀 함수를 활용하면 배열 목록을 트리 구조로 효율적으로 변환할 수 있으므로 데이터를 쉽게 탐색하고 구성할 수 있습니다.

위 내용은 계층적 배열 목록에서 트리 구조를 효율적으로 구축하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.