首页 > 编程语言 > 详细

PHP数组树状递归 -- 学习笔记(自己对于刚学的递归数组的一些理解)

时间:2017-01-12 13:22:23      阅读:283      评论:0      收藏:0      [点我收藏+]

echo ‘<hr>‘;
$arr = array(
array(‘id‘=>1,‘name‘=>‘小明爸‘,‘pid‘=>0),
array(‘id‘=>2,‘name‘=>‘小强爸‘,‘pid‘=>0),
array(‘id‘=>3,‘name‘=>‘小黑爸‘,‘pid‘=>0),
array(‘id‘=>4,‘name‘=>‘小明‘,‘pid‘=>1),
array(‘id‘=>5,‘name‘=>‘小强‘,‘pid‘=>2),
array(‘id‘=>6,‘name‘=>‘小黑‘,‘pid‘=>3),
array(‘id‘=>7,‘name‘=>‘小明儿子‘,‘pid‘=>4),
array(‘id‘=>8,‘name‘=>‘小强儿子‘,‘pid‘=>5),
array(‘id‘=>9,‘name‘=>‘小黑儿子‘,‘pid‘=>6),
);
/* foreach ($arr as $key => $value) {

echo $arr[$key][‘name‘];
echo $arr[$key][‘id‘];
}*/
function tree($arr,$pid=0){
foreach($arr as $key => $val){ //循环事先执行语句 执行完语句在判断 而递归算语句 所以是先找完在 通过循环再找下一个。
if($pid==$arr[$key][‘pid‘]){
echo $val[‘name‘].‘<br>‘;//小明爸=>小明=>小明儿子 因为小明爸在第一个 所以根据循环顺序从上往下 先从小明找以此类推 3 + 3 + 3
tree($arr,$val[‘id‘]); //根据对应的ID名 来找子辈PID名 且按父辈顺序查找 因为循环从上往下 符合该条件判断(id=pid)的数组的ID名
} //所以 ID变动 应该为 1 4 7 2 5 8 3 6 9
}

}
tree($arr,$pid=0);

PHP数组树状递归 -- 学习笔记(自己对于刚学的递归数组的一些理解)

原文:http://www.cnblogs.com/quanduanxiaozhong/p/6275796.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!