一個高效的數組轉樹結構的演算法實現

來源:互聯網
上載者:User

標籤:php   var_dump   add   set   parent   _id   nan   node   blog   

<?php// [email protected]function addNode(&$node, &$tree) {    $node_id = $node[‘id‘];    if (!isset($tree[$node_id])) {        $tree[$node_id] = $node;        $tree[$node_id][‘sub‘] = [];        $node[‘ref‘] = & $tree[$node_id];    }}function addNodeWithParent(&$node, &$nodes, &$tree) {    $pid = $node[‘pid‘];    if ($pid == 0) {        addNode($node, $tree);    } else {        $pnode = & $nodes[$pid];        if (!isset($pnode[‘ref‘])) {            addNodeWithParent($pnode, $nodes, $tree);        }        addNode($node, $pnode[‘ref‘][‘sub‘]);    }}
// 數組可以無序,必須要索引$nodes = [ 5 => [‘id‘ => 5, ‘name‘ => ‘node5‘, ‘pid‘ => 3], 1 => [‘id‘ => 1, ‘name‘ => ‘node1‘, ‘pid‘ => 0], 2 => [‘id‘ => 2, ‘name‘ => ‘node2‘, ‘pid‘ => 0], 3 => [‘id‘ => 3, ‘name‘ => ‘node3‘, ‘pid‘ => 1], 4 => [‘id‘ => 4, ‘name‘ => ‘node4‘, ‘pid‘ => 1], 6 => [‘id‘ => 6, ‘name‘ => ‘node6‘, ‘pid‘ => 2], 7 => [‘id‘ => 7, ‘name‘ => ‘node7‘, ‘pid‘ => 2], 8 => [‘id‘ => 8, ‘name‘ => ‘node8‘, ‘pid‘ => 0],];$tree = [];foreach($nodes as $i => &$node) { addNodeWithParent($node, $nodes, $tree);}var_dump($tree);

 

一個高效的數組轉樹結構的演算法實現

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.