2 lhetiger lhetiger 于 2017.07.17 00:17 提问

请教 php 递归效率问题 20C

/**

  • 递归获取下级数组 返回一维数组
  • @param array $data
  • @param number $pid
  • @return array
    */
    function getSons(&$data,$pid=0){
    static $arrTree = array();
    // $SonNode[] = $pid;
    foreach($data as $k=>$v){
    if($v['p_id'] == $pid){
    $arrTree[]=$v['id'];

        getSons($data,$v['id']);
    
    }
    

    }
    return $arrTree;
    }

当用户ID1下面有8000个会员。用此方法找出1的所有下级用户时,花费时间大约需要16秒,请教有没有更好的方法。提升运行效率。谢谢

2个回答

caozhy
caozhy   Ds   Rxr 2017.07.18 00:17

对结果分页,不要一次加载。

m0_37043345
m0_37043345   2017.07.21 16:03

把递归的结构放在参数中

Csdn user default icon
上传中...
上传图片
插入图片