久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

PHP迭代與遞歸實現(xiàn)無限級分類

這篇文章主要為大家詳細(xì)介紹了PHP迭代與遞歸實現(xiàn)無限級分類,具有一定的參考價值,感興趣的小伙伴們可以參考一下

無限級分類是開發(fā)中常見的情況,因此本文對常見的無限極分類算法進行總結(jié)歸納.

1.循環(huán)迭代實現(xiàn)

$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));

輸出:

PHP迭代與遞歸實現(xiàn)無限級分類

分析:

這個算法利用了循環(huán)迭代,將線性結(jié)構(gòu)按照父子關(guān)系以樹形結(jié)構(gòu)輸出,算法的關(guān)鍵在于使用了引用.

優(yōu)點:速度快,效率高.

缺點:數(shù)組的key值必須與id值相同,不便于取出數(shù)據(jù)(同樣使用迭代獲取數(shù)據(jù))

2.遞歸實現(xiàn)

$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>';
}

 輸出:

PHP迭代與遞歸實現(xiàn)無限級分類

分析:

利用了遞歸,數(shù)組的key值與id值可以不相同,最后以順序的結(jié)構(gòu)輸出數(shù)組

優(yōu)點:方便遍歷,查找父子元素

缺點:php不擅長遞歸,數(shù)據(jù)量大的情況下效率會顯著降低

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持。

【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡單分析了插值查找算法的概念、原理并結(jié)合實例形式分析了php實現(xiàn)針對有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實現(xiàn)服務(wù)端分頁的示例代碼,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
下面小編就為大家分享一篇PHP實現(xiàn)APP微信支付的實例講解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
這篇文章主要介紹了PHP實現(xiàn)的多維數(shù)組排序算法,結(jié)合實例形式對比分析了php針對多維數(shù)組及帶有鍵名的多維數(shù)組進行排序相關(guān)操作技巧與注意事項,需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實現(xiàn)無刷新文件上傳功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開發(fā)接口使用RSA進行加密解密方法,對此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 国产资源在线播放 | 日韩三级精品 | 欧美老少妇 | 午夜精品久久 | www.在线播放 | 亚洲香蕉在线 | 久久精品毛片 | 国产乱人伦 | 香蕉视频在线免费看 | 日韩成人在线免费观看 | 91l九色lporny | 久久免费精品视频 | 亚洲一区在线看 | 91精品国产日韩91久久久久久 | 午夜性色 | 麻豆av在线 | 国产一二 | 亚洲综合网站 | aaa国产精品| 午夜视频一区二区三区 | 免费在线小视频 | 欧美日韩一本 | 丰满少妇高潮在线观看 | 中文字幕在线免费观看 | 亚洲第一第二区 | 国产成人综合视频 | av在线精品 | 亚洲精品乱码久久久久久动漫 | 欧洲精品| 国产伦精品一区二区三区在线 | 亚洲欧美综合另类 | 国产91清纯白嫩初高中在线观看 | 亚洲精品tv | 日韩一级大片 | 国产一级一片免费播放放a 国产黄色大片 | 午夜xxx | 国产精品日韩精品 | 久久国产美女 | 免费一区二区三区 | 国产成人亚洲精品自产在线 | 福利片在线观看 |