全网整合营销服务商

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

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


相关文章: 建站主机解析:虚拟主机配置与服务器选择指南  建站之星各版本价格是多少?  江苏网站制作公司有哪些,江苏书法考级官方网站?  魔方云NAT建站如何实现端口转发?  网站制作与设计教程,如何制作一个企业网站,建设网站的基本步骤有哪些?  建站之星好吗?新手能否轻松上手建站?  如何通过山东自助建站平台快速注册域名?  建站之星CMS五站合一模板配置与SEO优化指南  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  太原网站制作公司有哪些,网约车营运证查询官网?  如何彻底卸载建站之星软件?  宝塔面板如何快速创建新站点?  公司网站设计制作厂家,怎么创建自己的一个网站?  已有域名和空间如何快速搭建网站?  营销式网站制作方案,销售哪个网站招聘效果最好?  建站主机数据库如何配置才能提升网站性能?  ,想在网上投简历,哪几个网站比较好?  如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  建站VPS选购需注意哪些关键参数?  如何选择美橙互联多站合一建站方案?  如何零成本快速生成个人自助网站?  如何快速登录WAP自助建站平台?  家族网站制作贴纸教程视频,用豆子做粘帖画怎么制作?  如何在景安云服务器上绑定域名并配置虚拟主机?  如何选择域名并搭建高效网站?  如何在建站宝盒中设置产品搜索功能?  如何在Golang中使用replace替换模块_指定本地或远程路径  如何构建满足综合性能需求的优质建站方案?  盘锦网站制作公司,盘锦大洼有多少5G网站?  网页制作模板网站推荐,网页设计海报之类的素材哪里好?  如何在IIS7上新建站点并设置安全权限?  建站之星官网登录失败?如何快速解决?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  网站海报制作教学视频教程,有什么免费的高清可商用图片网站,用于海报设计?  婚礼视频制作网站,学习*后期制作的网站有哪些?  成都网站制作价格表,现在成都广电的单独网络宽带有多少的,资费是什么情况呢?  安徽网站建设与外贸建站服务专业定制方案  非常酷的网站设计制作软件,酷培ai教育官方网站?  建站主机服务器选型指南与性能优化方案解析  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  已有域名和空间,如何快速搭建网站?  建站主机服务器选购指南:轻量应用与VPS配置解析  网站制作公司排行榜,四大门户网站排名?  建站之星备案流程有哪些注意事项?  如何在万网主机上快速搭建网站?  如何选择PHP开源工具快速搭建网站?  实现点击下箭头变上箭头来回切换的两种方法【推荐】  建站之星安装后如何自定义网站颜色与字体?  深圳 网站制作,深圳招聘网站哪个比较好一点啊? 

您的项目需求

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