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

PHP迭代與遞歸實(shí)現(xiàn)無(wú)限級(jí)分類

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

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

1.循環(huán)迭代實(shí)現(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迭代與遞歸實(shí)現(xiàn)無(wú)限級(jí)分類

分析:

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

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

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

2.遞歸實(shí)現(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迭代與遞歸實(shí)現(xiàn)無(wú)限級(jí)分類

分析:

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

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

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

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

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

相關(guān)文檔推薦

這篇文章主要介紹了PHP有序表查找之插值查找算法,簡(jiǎn)單分析了插值查找算法的概念、原理并結(jié)合實(shí)例形式分析了php實(shí)現(xiàn)針對(duì)有序表插值查找的相關(guān)操作技巧,需要的朋友可以參考下
下面小編就為大家分享一篇ThinkPHP整合datatables實(shí)現(xiàn)服務(wù)端分頁(yè)的示例代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
下面小編就為大家分享一篇PHP實(shí)現(xiàn)APP微信支付的實(shí)例講解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
這篇文章主要介紹了PHP實(shí)現(xiàn)的多維數(shù)組排序算法,結(jié)合實(shí)例形式對(duì)比分析了php針對(duì)多維數(shù)組及帶有鍵名的多維數(shù)組進(jìn)行排序相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
這篇文章主要為大家詳細(xì)介紹了php結(jié)合ajaxuploadfile實(shí)現(xiàn)無(wú)刷新文件上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
本篇文章給大家詳細(xì)介紹了PHP開發(fā)接口使用RSA進(jìn)行加密解密方法,對(duì)此有興趣的朋友可以學(xué)習(xí)下。
主站蜘蛛池模板: 日本高清不卡视频 | 欧美一区二区三区在线看 | 精国产品一区二区三区四季综 | 99精品电影| 黄色片av | 国产精品18hdxxxⅹ在线 | 午夜免费视频 | 国产一区亚洲 | 午夜电影网站 | 一级爱爱片 | 波多野结衣一区二区三区 | 欧美日韩午夜精品 | 亚洲国产成人精品女人久久久 | 九九99九九精彩46 | 日韩一区二区三区在线观看视频 | 日本一区二区影视 | 男人天堂手机在线视频 | 久久久久亚洲精品 | 三级视频在线观看 | 中文字幕 在线观看 | 国产激情免费视频 | 日韩电影中文字幕 | 久优草| 日韩欧美在线视频播放 | 激情久久久久 | 中文字幕在线观看 | 亚洲高清在线观看 | 国内精品一区二区 | 夏同学福利网 | 日韩国产高清在线观看 | av一区在线 | 欧美一区二区久久 | 一区二区中文字幕 | 国产精品福利网 | 国产在线精品一区二区三区 | 亚洲精品黄 | 欧美成人激情 | 日韩精品| 97超碰人人| 九一国产精品 | 久草网址|