首页 > php教程 > php手册 > 正文

PHP树-不需要递归,php树递归

php中文网
发布: 2016-07-06 14:25:09
原创
1287人浏览过

PHP树-不需要递归,php树递归

<span>/*</span><span>*
 * 创建父节点树形数组
 * 参数
 * $ar 数组,邻接列表方式组织的数据
 * $id 数组中作为主键的下标或关联键名
 * $pid 数组中作为父键的下标或关联键名
 * 返回 多维数组
 *</span><span>*/</span>
<span>function</span> find_parent(<span>$ar</span>, <span>$id</span>='id', <span>$pid</span>='pid'<span>) {
  </span><span>foreach</span>(<span>$ar</span> <span>as</span> <span>$v</span>) <span>$t</span>[<span>$v</span>[<span>$id</span>]] = <span>$v</span><span>;
  </span><span>foreach</span> (<span>$t</span> <span>as</span> <span>$k</span> => <span>$item</span><span>){
    </span><span>if</span>( <span>$item</span>[<span>$pid</span><span>] ){
      </span><span>if</span>( ! <span>isset</span>(<span>$t</span>[<span>$item</span>[<span>$pid</span>]]['parent'][<span>$item</span>[<span>$pid</span><span>]]) )
         </span><span>$t</span>[<span>$item</span>[<span>$id</span>]]['parent'][<span>$item</span>[<span>$pid</span>]] =& <span>$t</span>[<span>$item</span>[<span>$pid</span><span>]];
    }
  }
  </span><span>return</span> <span>$t</span><span>;
}


</span><span>/*</span><span>*
 * 创建子节点树形数组
 * 参数
 * $ar 数组,邻接列表方式组织的数据
 * $id 数组中作为主键的下标或关联键名
 * $pid 数组中作为父键的下标或关联键名
 * 返回 多维数组
 *</span><span>*/</span>
<span>function</span> find_child(<span>$ar</span>, <span>$id</span>='id', <span>$pid</span>='pid'<span>) {
  </span><span>foreach</span>(<span>$ar</span> <span>as</span> <span>$v</span>) <span>$t</span>[<span>$v</span>[<span>$id</span>]] = <span>$v</span><span>;
  </span><span>foreach</span> (<span>$t</span> <span>as</span> <span>$k</span> => <span>$item</span><span>){
    </span><span>if</span>( <span>$item</span>[<span>$pid</span><span>] ) {
      </span><span>$t</span>[<span>$item</span>[<span>$pid</span>]]['child'][<span>$item</span>[<span>$id</span>]] =& <span>$t</span>[<span>$k</span><span>];
    }
  }
  </span><span>return</span> <span>$t</span><span>;
}

    </span><span>$data</span> = <span>array</span><span>(
      </span><span>array</span>('ID'=>1, 'PARENT'=>0, 'NAME'=>'祖父'),
      <span>array</span>('ID'=>2, 'PARENT'=>1, 'NAME'=>'父亲'),
      <span>array</span>('ID'=>3, 'PARENT'=>1, 'NAME'=>'叔伯'),
      <span>array</span>('ID'=>4, 'PARENT'=>2, 'NAME'=>'自己'),
      <span>array</span>('ID'=>5, 'PARENT'=>4, 'NAME'=>'儿子'),<span>
    );

    </span><span>$p</span> = find_parent(<span>$data</span>, 'ID', 'PARENT'<span>);
    </span><span>$c</span> = find_child(<span>$data</span>, 'ID', 'PARENT'<span>);
    </span><span>Print_r</span> (<span>$c</span>);
登录后复制
登录后复制

执行效果:

zyupload四种不同的上传PHP版
zyupload四种不同的上传PHP版

zyupload四种不同的上传PHP版

zyupload四种不同的上传PHP版 110
查看详情 zyupload四种不同的上传PHP版
登录后复制
<span>Array</span><span>
(
    [</span>1] => <span>Array</span><span>
        (
            [ID] </span>=> 1<span>
            [PARENT] </span>=> 0<span>
            [NAME] </span>=><span> 祖父
            [child] </span>=> <span>Array</span><span>
                (
                    [</span>2] => <span>Array</span><span>
                        (
                            [ID] </span>=> 2<span>
                            [PARENT] </span>=> 1<span>
                            [NAME] </span>=><span> 父亲
                            [child] </span>=> <span>Array</span><span>
                                (
                                    [</span>4] => <span>Array</span><span>
                                        (
                                            [ID] </span>=> 4<span>
                                            [PARENT] </span>=> 2<span>
                                            [NAME] </span>=><span> 自己
                                            [child] </span>=> <span>Array</span><span>
                                                (
                                                    [</span>5] => <span>Array</span><span>
                                                        (
                                                            [ID] </span>=> 5<span>
                                                            [PARENT] </span>=> 4<span>
                                                            [NAME] </span>=><span> 儿子
                                                        )

                                                )

                                        )

                                )

                        )

                    [</span>3] => <span>Array</span><span>
                        (
                            [ID] </span>=> 3<span>
                            [PARENT] </span>=> 1<span>
                            [NAME] </span>=><span> 叔伯
                        )

                )

        )

    [</span>2] => <span>Array</span><span>
        (
            [ID] </span>=> 2<span>
            [PARENT] </span>=> 1<span>
            [NAME] </span>=><span> 父亲
            [child] </span>=> <span>Array</span><span>
                (
                    [</span>4] => <span>Array</span><span>
                        (
                            [ID] </span>=> 4<span>
                            [PARENT] </span>=> 2<span>
                            [NAME] </span>=><span> 自己
                            [child] </span>=> <span>Array</span><span>
                                (
                                    [</span>5] => <span>Array</span><span>
                                        (
                                            [ID] </span>=> 5<span>
                                            [PARENT] </span>=> 4<span>
                                            [NAME] </span>=><span> 儿子
                                        )

                                )

                        )

                )

        )

    [</span>3] => <span>Array</span><span>
        (
            [ID] </span>=> 3<span>
            [PARENT] </span>=> 1<span>
            [NAME] </span>=><span> 叔伯
        )

    [</span>4] => <span>Array</span><span>
        (
            [ID] </span>=> 4<span>
            [PARENT] </span>=> 2<span>
            [NAME] </span>=><span> 自己
            [child] </span>=> <span>Array</span><span>
                (
                    [</span>5] => <span>Array</span><span>
                        (
                            [ID] </span>=> 5<span>
                            [PARENT] </span>=> 4<span>
                            [NAME] </span>=><span> 儿子
                        )

                )

        )

    [</span>5] => <span>Array</span><span>
        (
            [ID] </span>=> 5<span>
            [PARENT] </span>=> 4<span>
            [NAME] </span>=><span> 儿子
        )

)</span>
登录后复制
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号