全网整合营销服务商

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

免费咨询热线: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 


相关文章: 电脑免费海报制作网站推荐,招聘海报哪个网站多?  南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?  免费视频制作网站,更新又快又好的免费电影网站?  视频网站app制作软件,有什么好的视频聊天网站或者软件?  如何通过VPS建站实现广告与增值服务盈利?  番禺网站制作公司哪家值得合作,番禺图书馆新馆开放了吗?  学校建站服务器如何选型才能满足性能需求?  广州美橙建站如何快速搭建多端合一网站?  如何选择香港主机高效搭建外贸独立站?  广州建站公司哪家好?十大优质服务商推荐  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  如何在Golang中指定模块版本_使用go.mod控制版本号  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南  内网网站制作软件,内网的网站如何发布到外网?  独立制作一个网站多少钱,建立网站需要花多少钱?  jQuery 常见小例汇总  建站OpenVZ教程与优化策略:配置指南与性能提升  品牌网站制作公司有哪些,买正品品牌一般去哪个网站买?  网站制作话术技巧,网站推广做的好怎么话术?  金*站制作公司有哪些,金华教育集团官网?  建站之星展会模版如何一键下载生成?  常州自助建站:操作简便模板丰富,企业个人快速搭建网站  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  ,巨量百应是干嘛的?  如何选择PHP开源工具快速搭建网站?  企业微网站怎么做,公司网站和公众号有什么区别?  已有域名能否直接搭建网站?  保定网站制作方案定制,保定招聘的渠道有哪些?找工作的人一般都去哪里看招聘信息?  如何在万网开始建站?分步指南解析  如何选择高效响应式自助建站源码系统?  宝塔面板创建网站无法访问?如何快速排查修复?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  建站之星免费模板:自助建站系统与智能响应式一键生成  如何在IIS中新建站点并配置端口与IP地址?  网站制作需要会哪些技术,建立一个网站要花费多少?  建站org新手必看:2024最新搭建流程与模板选择技巧  如何快速查询网站的真实建站时间?  外贸公司网站制作哪家好,maersk船公司官网?  网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?  php条件判断怎么写_ifelse和switchcase的使用区别【对比】  公司网站的制作公司,企业网站制作基本流程有哪些?  文字头像制作网站推荐软件,醒图能自动配文字吗?  香港服务器租用费用高吗?如何避免常见误区?  如何在建站之星绑定自定义域名?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  C#怎么创建控制台应用 C# Console App项目创建方法  浅谈Javascript中的Label语句  如何快速搭建高效可靠的建站解决方案? 

您的项目需求

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