Maison >développement back-end >tutoriel php >php递归问题
<?php $area = array( 0=>array('id'=>1,'name'=>'中国','pid'=>0), 1=>array('id'=>2,'name'=>'北京','pid'=>1), ); print_r(catsort($area)); function catsort($cate, $pid = 0){ $arr = array(); foreach($cate as $v){ if ($v['pid'] == $pid){ $arr[] = $v; $arr = array_merge($arr, catsort($cate ,$v['id'])); //$arr[] = $v; } } return $arr; } ?>
你至少应该阅读过关于书的遍历吧?
递归就是遍历一颗树
根据访问结点操作发生位置命名:
① NLR:前序遍历(PreorderTraversal亦称(先序遍历))
??访问根结点的操作发生在遍历其左右子树之前。
② LNR:中序遍历(InorderTraversal)
??访问根结点的操作发生在遍历其左右子树之中(间)。
③ LRN:后序遍历(PostorderTraversal)
??访问根结点的操作发生在遍历其左右子树之后。
$arr[] = $v放在$arr = array_merge($arr, catsort($cate ,$v['id']))前面
是前序遍历
放到$arr = array_merge($arr, catsort($cate ,$v['id']))后面
是后序遍历
那为什么放在前面就是前序,后面就是后序,不是很理解,能在说清楚点吗
foreach($cate as $v){ if ($v['pid'] == $pid){ $arr[] = $v; $arr = array_merge($arr, catsort($cate ,$v['id'])); //$arr[] = $v; } }
foreach($cate as $v){ if ($v['pid'] == $pid){ //$arr[] = $v; $arr = array_merge($arr, catsort($cate ,$v['id'])); //这里catsort进入递归 $arr[] = $v; } }
搞懂了,thank you