那么,首先, " /> a一级黄色片,一区二区三区四区精品视频,国内精品视频一区

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

php實現(xiàn)的常見排序算法匯總

本文匯總了常見的php排序算法,在進(jìn)行算法設(shè)計的時候有不錯的借鑒價值?,F(xiàn)分享給大家供參考之用。具體如下:

一、插入排序

用文字簡單的描述,比如說$arr = array(4,2,4,6,3,6,1,7,9); 這樣的一組數(shù)字進(jìn)行順序排序:
那么,首先,拿數(shù)組的第二個元素和第一元素比較,假如第一個元素大于第二元素,那么就讓兩者位置互換,接下來,拿數(shù)組的第三個元素,分別和第二個,第一個元素比較,假如第三個元素小,那么就互換。依次類推。這就是插入排序,它的時間頻度是:1+2+...+(n-1)=(n^2)/2。則它的時間復(fù)雜度為O(n^2).

php實現(xiàn)代碼如下:

<?phpfunction insertSort($arr){   $count = count($arr);   if($count<2){  return $arr;    }   for($i=1;$i<$count;$i++){   $tmp = $arr[$i];   $j=$i-1;   while(j>=0&&$arr[$j]<$arr[$i]){  $arr[$i] = $arr[$j];             $arr[$j] = $tmp;  $j--;   }    }    return $arr;  }?>

二、選擇排序

選擇排序用語言描述的話,可以這樣,如:$arr = array(4,3,5,2,1);

首先,拿第一個和后面所有的比,找出最小的那個數(shù)字,然后和第一個數(shù)組互換(當(dāng)然,如果是第一個最小,那么就不用互換了),接著循環(huán),即:拿第二個和后面的比較,找出最小的數(shù)字,然后和第二個數(shù)字互換,依次類推,也就是說每次都是找出剩余最小的值。 可得到:第一次,時間頻度 是n, (第一個和后面的n-1個比較,找到最小的,再看是不是第一個,不是第一個的話進(jìn)行互換) 在往后,依次是 減一 。 它的時間復(fù)雜度,也是O(n^2);

php實現(xiàn)代碼如下:

<?phpfunction selectSort($arr){   $count = count($arr);   if($count<2){  return $arr;    }   for($i=0;$i<$count;$i++){   $min=$i;   for(j=$i+1;$j<$count;$j++){  if($arr[$min]>$arr[$j]){    $min = $j; //找到最小的那個元素的下標(biāo)  }   }   if($min!=$i){//如果下標(biāo)不是$i 則互換。   $tmp= $arr[$i];               $arr[$i] = $arr[$min];    $arr[$min] = $tmp;    }    }    return $arr;  }?>

三、冒泡排序  
    
冒泡排序其實上是和選擇排序相比,并無明顯差別。都是找到最小的,放到最左端。依次循環(huán)解決問題。差別在于冒泡排序的交換位置的次數(shù)較多,而選擇排序則是找到最小的元素的下標(biāo),然后直接和最左端的交換位置。


php實現(xiàn)代碼如下:

<?phpfunction selectSort($arr){   $count = count($arr);   if($count<2){  return $arr;    }   for($i=0;$i<$count;$i++){   for(j=$i+1;$j<$count;$j++){  if($arr[$i]>$arr[$j]){    $tmp= $arr[$i];               $arr[$i] = $arr[$i];    $arr[$i] = $tmp;  }   }    }    return $arr;  }?>

四、快速排序

快速排序,用語言來形容的話,從數(shù)組中選擇一個值$a,然后和其余元素進(jìn)行比較,比$a大的放到數(shù)組right中,反之,放到數(shù)組left中。然后將left right 分別進(jìn)行遞歸調(diào)用,即:再細(xì)分left right ,最后進(jìn)行數(shù)組的合并。

php實現(xiàn)快速排序:

<?phpfunction mySort($arr){   $count = count($arr);   if($count<2){  return $arr;    }   $key = $arr[0];//選擇第一個元素作為比較元素,可選其他    $left = array();           $right = array();    for($i=1;$i<$count;$i++){   if($key>=$arr[$i]){  $left[] = $arr[$i];    }else{  $right[] = $arr[$i];    }    }    $left = mySort($left);    $right = mySort($right);    $result = array_merge($left,$right);    return $result;  }?>

五、歸并排序

其實歸并排序是一種拆分,合并的思想。和快速排序思想有共通之處,左邊一堆,右邊一堆,然后進(jìn)行合并。通過遞歸實現(xiàn)排序。 區(qū)別之處呢?  他們的區(qū)別也是思想上本質(zhì)的區(qū)別,快速排序的拆分,是選擇了特定的值進(jìn)行大小比較,從而分為left 和 right 。也就是小的一堆放入left,大的一堆放入right。而后,小的left 再細(xì)分為left1  right1。。。。通過進(jìn)行類似的遞歸完成排序。也就是說,一直細(xì)分下去,遞歸最末尾的left1就是最小值。

而歸并排序,是從幾何上的左右切分,一直遞歸切分成2或者1的最小粒度的數(shù)組,然后才開始進(jìn)行比較大小,然后合并。此處的比較大小是:兒子left的元素 和兒子的right元素 進(jìn)行比較,而后進(jìn)行排序合并成為父親left或者right。在此,直到拿到各自排序合并完成最后兩個數(shù)組:最起初的left 和right,也僅僅直到他們各自的順序,并不能確認(rèn)整個數(shù)組的順序,還是需要通過最終的left right 比較后合并才能完成真正意義上的排序。

<?phpfunction gbSort($arr){    if(count($arr)<=1){return $arr;}    $min = floor(count($arr)/2);//取中間數(shù)字進(jìn)行拆分    $left = array_slice($arr,0,$min);    $right = array_slice($arr,$min);    $left = gbSort($left); //遞歸    $right = gbSort($right);    return get_merge($left,$right);//調(diào)用排序合并函數(shù)進(jìn)行合并}function get_merge($left,$right){    while(count($left) && count($right)){        $m[] = $left[0]>$right[0] ? array_shift($right) : array_shift($left);        //進(jìn)行比較,小的移除,并且放入到數(shù)組$m中。    }    return arr_merge($m,$left,$right);//進(jìn)行合并(由于不知道left right 哪個會為空,所以進(jìn)行統(tǒng)一合并)}?>

六、堆排序

本例中fixDown函數(shù)實現(xiàn)對某一個節(jié)點的向下調(diào)整,這里默認(rèn)的是起始節(jié)點為1,方便計算父子節(jié)點關(guān)系

注:

起始節(jié)點為1的父子關(guān)系: 父節(jié)點k, 子節(jié)點為2K、2k+1     子節(jié)點j, 父節(jié)點為 floor(j/2)  floor為向下取整
起始節(jié)點為0的父子關(guān)系: 父節(jié)點k, 子節(jié)點為2K+1, 2k+2   子節(jié)點j, 父節(jié)點為 floor((j-1)/2)

參數(shù)$k為調(diào)整點位置, $lenth為數(shù)組長度,也就是從1起始到最后一個節(jié)點的坐標(biāo).

<?phpfunction fixDown(&$arr, $k, $lenth){  while(2*$k<=$lenth) { //只要當(dāng)前節(jié)點有子節(jié)點, 就需要繼續(xù)該循環(huán)    $j = $k*2;    if ($j<$lenth && $arr[$j]<$arr[$j+1]) $j++;  // 只要子節(jié)點有右節(jié)點,且右節(jié)點比左節(jié)點大,那么切換到右節(jié)點操作。    if ($arr[$j] < $arr[$k]) break; // 如果子節(jié)點都沒有父節(jié)點大, 那么調(diào)整結(jié)束。    exch($arr[$j], $arr[$k]);     $k = $j;  }}function exch(&$a, &$b) {  $tmp = $a; $a = $b; $b = $tmp;}function headSort(&$arr){  $len = count($arr);  array_unshift($arr, NULL);  for($i=$len/2;$i>=1;$i--) {    fixDown($arr, $i, $len);  }  while($len>1) {    exch($arr[1], $arr[$len]);    fixDown($arr, 1, --$len);  }  array_shift($arr);}$arr = array(4,6,4,9,2,3);headSort($arr);?>

希望本文所述排序算法實例對大家的php程序設(shè)計有所幫助。

php技術(shù)php實現(xiàn)的常見排序算法匯總,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 韩国电影《爱欲》| 30届金鹰奖获奖名单| 洪金宝电影| 摇曳山庄的幽灵| 潘月彤| 误杀1演员表| 演员李明个人资料| 怀秋| 我的仨妈俩爸演员表| 大奉打更人电视剧在线| 罗云熙《尸语者》| 妥协电影在线观看完整版中文 | 夜店 电影| 赵国华| 小鲤鱼历险记肥鲶鱼| 超薄轻舞玉女女裤广场舞| 性的张力短片集| 国产电影网站| 心太狂| 《承欢记》电视剧| 王渝萱主演的电影大全| kami什么意思| 洞房电影| 欧美一级淫片007| jamie dornan| 云南的旅游攻略| 荡寇电视剧演员表| 团结就是力量歌词电子版| 轮回乐队| 绝伦海女| 《在一起》电影免费观看| 处女膜视频| 庞勇| 鬼吹灯之精绝古城演员表| 野蛮人电影| 今日航班一览表| 大内群英 电视剧| 荒岛惊魂 电影| 今日航班一览表| 女演员佟欣简介| 电影《大突围》免费观看国语 |