배열 목록에서 트리 구조 구축
계층 관계가 있는 항목의 배열 목록이 주어지면 어떻게 효율적으로 이를 트리 구조로 변환할 수 있습니까? 중첩 트리 구조?
해결책:
복잡한 데이터베이스 최적화를 사용하지 않고 이 변환을 수행하려면 재귀 함수를 사용할 수 있습니다.
$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 중국어 웹사이트의 기타 관련 기사를 참조하세요!