程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 樹形算法

樹形算法

編輯:關於PHP編程

1,pid=>0), array(id=>2,pid=>0), array(id=>3,pid=>2), array(id=>4,pid=>0), array(id=>5,pid=>3), array(id=>6,pid=>1), array(id=>7,pid=>1), array(id=>8,pid=>6), array(id=>9,pid=>7), array(id=>10,pid=>9) ); //排序函數 function cmd($a,$b) { if($a[pid]==$b[pid]) return 0; return $a[pid]>$b[pid]?1:-1; } //排序,為避免數據中父節點在子節點後面出現,這種情況在多次修改數據後經常會發生的 //排序的目的就是防止這種情況造成的混亂 uasort($ar,cmd); //定義目標數組 $d = array(); //定義索引數組,用於記錄節點在目標數組的位置 $ind = array(); foreach($ar as $v) { $v[child] = array(); //給每個節點附加一個child項 if($v[pid] == 0) { $i = count($d); $d[$i] = $v; $ind[$v[id]] =& $d[$i]; }else { $i = count($ind[$v[pid]][child]); $ind[$v[pid]][child][$i] = $v; $ind[$v[id]] =& $ind[$v[pid]][child][$i]; } } //檢查結果 print_r($d); ?> 算法特點:利用B+樹概念,只用一次循環就可生成樹形數組

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved