zoukankan      html  css  js  c++  java
  • php 数组变成树状型结构

    <? php
    $stime = microtime(true);
    $nodes = [
        ['id' = > 1, 'pid' = > 0, 'name' = > 'a'],
        ['id' = > 2, 'pid' = > 0, 'name' = > 'b'],
        ['id' = > 3, 'pid' = > 1, 'name' = > 'c'],
        ['id' = > 4, 'pid' = > 2, 'name' = > 'd'],
        ['id' = > 5, 'pid' = > 6, 'name' = > 'e'],
        ['id' = > 6, 'pid' = > 4, 'name' = > 'f'],
        ['id' = > 7, 'pid' = > 6, 'name' = > 'g'],
        ['id' = > 8, 'pid' = > 6, 'name' = > 'h'],
        ['id' = > 9, 'pid' = > 10, 'name' = > 'i'],
        ['id' = > 10, 'pid' = > 8, 'name' = > 'j']
    ];
     
    function tree($list, $id = 'id', $pid = 'pid', $name = 'name') {
        $data = [];
        foreach($list as $row) {
            $data[$row[$id]][$name] = $row[$name];
            $data[$row[$pid]]['children'][$row[$id]] = & $data[$row[$id]];
        }
        return isset($data[0]['children']) ? $data[0]['children'] : [];
    }
    print_r(tree($nodes));
    $etime = microtime(true);
    echo '运行后内存:'.round(memory_get_usage() / 1024 / 1024, 2).
    'MB 
    ';
    $total = $etime - $stime; //计算差值
    echo "[页面执行时间:{$total} ]秒"; ?>

    您的资助是我最大的动力!
    金额随意,欢迎来赏!

    如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的推荐按钮。
    如果,您希望更容易地发现我的新博客,不妨点击一下绿色通道的关注我

    如果,想给予我更多的鼓励,求打

    因为,我的写作热情也离不开您的肯定支持,感谢您的阅读!

  • 相关阅读:
    弱网测试(分析篇)
    弱网测试(资料罗列篇)
    2018年上半年系统分析师上午试题答案
    2018年上半年系统分析师案例分析答案
    测试执行过程注意事项
    略看操作系统
    Activity生命周期
    Android中的数据存储
    Android 进程生命周期 Process Lifecycle
    Android学习链接大放送
  • 原文地址:https://www.cnblogs.com/GreenForestQuan/p/7160723.html
Copyright © 2011-2022 走看看