首页 >后端开发 >php教程 >如何高效地将数组列表转换为层次树结构?

如何高效地将数组列表转换为层次树结构?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-12-04 14:21:10165浏览

How to Efficiently Convert an Array List into a Hierarchical Tree Structure?

从数组列表创建数组树

如果您有一个具有层次关系的元素列表,请将其转换为树状结构结构可能至关重要。在处理需要高效组织和检索的复杂数据时,这种转换特别有用。

以以下列表为例:

[
  {id: 100, parentId: 0, name: 'a'},
  {id: 101, parentId: 100, name: 'a'},
  {id: 102, parentId: 101, name: 'a'},
  {id: 103, parentId: 101, name: 'a'},
]

目标是将这个列表重新组织为分层结构树结构,其中每个元素都有对其父元素及其子元素(如果有)的引用。

以下代码演示了完成此转换的一种有效方法snippet:

<?php

$arr = [
    ['id' => 100, 'parentId' => 0, 'name' => 'a'],
    ['id' => 101, 'parentId' => 100, 'name' => 'a'],
    ['id' => 102, 'parentId' => 101, 'name' => 'a'],
    ['id' => 103, 'parentId' => 101, 'name' => 'a'],
];

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

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

此代码通过根据元素的parentId 对元素进行分组来有效地处理输入列表。然后,它递归地构建树结构,用其子元素填充每个元素。生成的树提供了原始列表的分层表示,使基于父子关系的导航和检索数据变得更加容易。

以上是如何高效地将数组列表转换为层次树结构?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn