数据结构和算法分析

PHP无限极分类

2017-12-15  本文已影响0人  岸边露伴一动不动
最近工作中用到了关于无限极分类的功能,于是查询了一下相关内容。
无限极分类有两种实现方式
     - 毗邻目录模式
     - 预排序遍历树算法
要了解这两种方式具体内容,可以去查看这篇博客: 左右值无限分类实现算法
本文主要提供两种将符合无限极分类格式的二维数组转化为树状形式数组方法。
function getNodeTree(&$list,&$tree,$pid=0){
    foreach($list as $key=>$value){
        if($pid == $value['parent']){
            $tree[$value['id']]=$value;
            unset($list[$key]);
            getNodeTree($list,$tree[$value['id']]['children'],$value['id']);
        }
    }
}

其中第一个参数为需要处理的数组,$tree即为最后所需结果。

以下是将符合预排序遍历树算法的二维数组转化为树形结构数组的方法。

function getNodeTree($arr,&$tree,$last_level=-1)
{
  static $used_key = [];
  foreach ($arr as $key => $value) {
    if ( in_array($key,$used_key) ) {
      continue;
    }
    $current_level = $value['level'];
    $next_level = isset($arr[$key+1])?$arr[$key+1]['level']:-1;
    if ( $current_level >= $last_level ) {
      $tree[]=$value;
      end($tree);
      $index = key($tree);
      $used_key[] = $key;
      unset($arr[$key]);
      $last_level = $value['level'];
      if ( $next_level > $current_level ) {
        getNodeTree($arr,$tree[$index]['children'],$last_level);
      }
      if ( $next_level == $current_level ) {
        getNodeTree($arr,$tree,$last_level);
      }
    }else{
      break;
    }
  }
}

其中第一个参数为需要处理的数组,数组要求必须按左值增加顺序排序,$tree为最后所需结果。

上一篇 下一篇

猜你喜欢

热点阅读