全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

PHP迭代与递归实现无限级分类

无限级分类是开发中常见的情况,因此本文对常见的无限极分类算法进行总结归纳.

1.循环迭代实现

$arr = [
  1=>['id'=>1,'name'=>'父1','father'=>NULL],
  2=>['id'=>2,'name'=>'父2','father'=>NULL],
  3=>['id'=>3,'name'=>'父3','father'=>NULL],
  4=>['id'=>4,'name'=>'儿1-1','father'=>1],
  5=>['id'=>5,'name'=>'儿1-2','father'=>1],
  6=>['id'=>6,'name'=>'儿1-3','father'=>1],
  7=>['id'=>7,'name'=>'儿2-1','father'=>2],
  8=>['id'=>8,'name'=>'儿2-1','father'=>2],
  9=>['id'=>9,'name'=>'儿3-1','father'=>3],
  10=>['id'=>10,'name'=>'儿3-1-1','father'=>9],
  11=>['id'=>11,'name'=>'儿1-1-1','father'=>4],
  12=>['id'=>12,'name'=>'儿2-1-1','father'=>7],
];
function generateTree($items){
  $tree = array();
  foreach($items as $item){
    if(isset($items[$item['father']])){
      $items[$item['father']]['son'][] = &$items[$item['id']]; 
    }else{
      $tree[] = &$items[$item['id']];
    }
  }
  return $tree;
}
$tree = generateTree($arr);
print_r(json_encode($tree));

输出:

分析:

这个算法利用了循环迭代,将线性结构按照父子关系以树形结构输出,算法的关键在于使用了引用.

优点:速度快,效率高.

缺点:数组的key值必须与id值相同,不便于取出数据(同样使用迭代获取数据)

2.递归实现

$arr = [
  0=>['id'=>1,'name'=>'父1','father'=>0],
  1=>['id'=>2,'name'=>'父2','father'=>0],
  2=>['id'=>3,'name'=>'父3','father'=>0],
  3=>['id'=>4,'name'=>'儿1-1','father'=>1],
  4=>['id'=>5,'name'=>'儿1-2','father'=>1],
  5=>['id'=>6,'name'=>'儿1-3','father'=>1],
  6=>['id'=>7,'name'=>'儿2-1','father'=>2],
  7=>['id'=>8,'name'=>'儿2-1','father'=>2],
  8=>['id'=>9,'name'=>'儿3-1','father'=>3],
  9=>['id'=>10,'name'=>'儿3-1-1','father'=>9],
  10=>['id'=>11,'name'=>'儿1-1-1','father'=>4],
  11=>['id'=>12,'name'=>'儿2-1-1','father'=>7],
];
function generateTree($arr,$id,$step){
  static $tree=[];
  foreach($arr as $key=>$val) {
    if($val['father'] == $id) {
      $flg = str_repeat('└―',$step);
      $val['name'] = $flg.$val['name'];
      $tree[] = $val;
      generateTree($arr , $val['id'] ,$step+1);
    }
  }
  return $tree;
}
$tree = generateTree($arr,0,0);
foreach ($tree as $val){
  echo $val['name'].'<br>';
}

 输出:

分析:

利用了递归,数组的key值与id值可以不相同,最后以顺序的结构输出数组

优点:方便遍历,查找父子元素

缺点:php不擅长递归,数据量大的情况下效率会显著降低

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# PHP  # 无限级分类  # php求斐波那契数的两种实现方式【递归与递推】  # php菜单/评论数据递归分级算法的实现方法  # PHP实现无限极分类的两种方式示例【递归和引用方式】  # PHP利用递归函数实现无限级分类的方法  # PHP自定义递归函数实现数组转JSON功能【支持GBK编码】  # PHP递归写入MySQL实现无限级分类数据操作示例  # PHP数组递归排序实现方法示例  # PHP实现递归的三种方法  # 递归  # 迭代  # 遍历  # 速度快  # 量大  # 关键在于  # 大家多多  # 情况下  # 使用了  # 无限极  # 效率高  # NULL  # id  # father  # generateTree  # items  # function  # nbsp  # pre  # son 


相关文章: 车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?  如何设计高效校园网站?  广州美橙建站如何快速搭建多端合一网站?  网站设计制作公司地址,网站建设比较好的公司都有哪些?  建站之星后台密码遗忘或太弱?如何重置与强化?  北京制作网站的公司,北京铁路集团官方网站?  头像制作网站在线制作软件,dw网页背景图像怎么设置?  广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  一键制作网站软件下载安装,一键自动采集网页文档制作步骤?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  如何通过虚拟主机空间快速建站?  网站制作新手教程,新手建设一个网站需要注意些什么?  广州建站公司哪家好?十大优质服务商推荐  东莞市网站制作公司有哪些,东莞找工作用什么网站好?  电脑免费海报制作网站推荐,招聘海报哪个网站多?  Python如何创建带属性的XML节点  网站制作免费,什么网站能看正片电影?  大连网站制作公司哪家好一点,大连买房网站哪个好?  内网网站制作软件,内网的网站如何发布到外网?  常州企业建站如何选择最佳模板?  建站之星后台管理:高效配置与模板优化提升用户体验  香港服务器网站卡顿?如何解决网络延迟与负载问题?  韩国代理服务器如何选?解析IP设置技巧与跨境访问优化指南  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  网站专业制作公司,网站编辑是做什么的?好做吗?工作前景如何?  ,交易猫的商品怎么发布到网站上去?  再谈Python中的字符串与字符编码(推荐)  C++时间戳转换成日期时间的步骤和示例代码  如何用IIS7快速搭建并优化网站站点?  建站主机服务器选购指南:轻量应用与VPS配置解析  红河网站制作公司,红河事业单位身份证如何上传?  如何通过虚拟机搭建网站?详细步骤解析  如何做网站制作流程,*游戏网站怎么搭建?  h5网站制作工具有哪些,h5页面制作工具有哪些?  高端企业智能建站程序:SEO优化与响应式模板定制开发  招商网站制作流程,网站招商广告语?  建站之星如何修改网站生成路径?  手机网站制作与建设方案,手机网站如何建设?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  攀枝花网站建设,攀枝花营业执照网上怎么年审?  制作网站外包平台,自动化接单网站有哪些?  网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?  网页设计网站制作软件,microsoft office哪个可以创建网页?  高防服务器租用如何选择配置与防御等级?  专业网站建设制作报价,网页设计制作要考什么证?  孙琪峥织梦建站教程如何优化数据库安全?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  建站主机选择指南:服务器配置与SEO优化实战技巧  logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?  在线制作视频网站免费,都有哪些好的动漫网站? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。