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