中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

PHP排序算法中歸并排序MergingSort的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹了PHP排序算法中歸并排序Merging Sort的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

成都創(chuàng)新互聯(lián)公司是一家專(zhuān)業(yè)提供永福企業(yè)網(wǎng)站建設(shè),專(zhuān)注與網(wǎng)站設(shè)計(jì)、做網(wǎng)站、HTML5建站、小程序制作等業(yè)務(wù)。10年已為永福眾多企業(yè)、政府機(jī)構(gòu)等服務(wù)。創(chuàng)新互聯(lián)專(zhuān)業(yè)網(wǎng)絡(luò)公司優(yōu)惠進(jìn)行中。

本文實(shí)例講述了PHP排序算法之歸并排序(Merging Sort)。分享給大家供大家參考,具體如下:

基本思想:

歸并排序:就是利用歸并(合并)的思想實(shí)現(xiàn)的排序方法。它的原理是假設(shè)初始序列含有 n 個(gè)元素,則可以看成是 n 個(gè)有序的子序列,每個(gè)子序列的長(zhǎng)度為 1,然后兩兩歸并,得到 ? n / 2? (? x ? 表示不小于 x 的最小整數(shù))個(gè)長(zhǎng)度為 2 或 1 的有序序列;再兩兩歸并,······,如此重復(fù),直至得到一個(gè)長(zhǎng)度為 n 的有序序列為止,這種排序方法就成為 2 路歸并排序。

一、歸并的過(guò)程:

a[i] 取 a 數(shù)組的前部分(已經(jīng)排好序),a[j] 取 a 數(shù)組的后部分(已經(jīng)排好序)

r 數(shù)組存儲(chǔ)排好序的 a 數(shù)組

比較 a[i]和 a[j] 的大小,若 a[i] ≤ a[j],則將第一個(gè)有序表中的元素 a[i] 復(fù)制到 r[k] 中,并令 i 和 k 分別加上 1;否則將第二個(gè)有序表中的元素 a[j] 復(fù)制到 r[k] 中,并令 j 和 k 分別加上 1,如此循環(huán)下去,直到其中一個(gè)有序表取完,然后再將另一個(gè)有序表中剩余的元素復(fù)制到 r 中從下標(biāo) k 到下標(biāo) t 的單元。歸并排序的算法我們通常用遞歸實(shí)現(xiàn),先把待排序區(qū)間 [s,t] 以中點(diǎn)二分,接著把左邊子區(qū)間排序,再把右邊子區(qū)間排序,最后把左區(qū)間和右區(qū)間用一次歸并操作合并成有序的區(qū)間 [s,t]。

二、歸并操作:

歸并操作(merge),也叫歸并算法,指的是將兩個(gè)順序序列合并成一個(gè)順序序列的方法。

如 設(shè)有數(shù)列{6,202,100,301,38,8,1}

初始狀態(tài):6 , 202 , 100 , 301 , 38 , 8,1

第一次歸并后:{6,202},{100,301},{8,38},{1},比較次數(shù):3;

第二次歸并后:{6,100,202,301},{1,8,38},比較次數(shù):4;

第三次歸并后:{1,6,8,38,100,202,301},比較次數(shù):4;

總的比較次數(shù)為:3+4+4=11,;

逆序數(shù)為14;

三、算法描述:

歸并操作的工作原理如下:

第一步:申請(qǐng)空間,使其大小為兩個(gè)已經(jīng)排序序列之和,該空間用來(lái)存放合并后的序列

第二步:設(shè)定兩個(gè)指針,最初位置分別為兩個(gè)已經(jīng)排序序列的起始位置

第三步:比較兩個(gè)指針?biāo)赶虻脑兀x擇相對(duì)小的元素放入到合并空間,并移動(dòng)指針到下一位置

重復(fù)步驟3直到某一指針超出序列尾

將另一序列剩下的所有元素直接復(fù)制到合并序列尾

PHP排序算法中歸并排序Merging Sort的示例分析

算法實(shí)現(xiàn):

我們先來(lái)看看主函數(shù)部分:

//交換函數(shù)
function swap(array &$arr,$a,$b){
  $temp = $arr[$a];
  $arr[$a] = $arr[$b];
  $arr[$b] = $temp;
}
//歸并算法總函數(shù)
function MergeSort(array &$arr){
  $start = 0;
  $end = count($arr) - 1;
  MSort($arr,$start,$end);
}

在總函數(shù)中,我們只調(diào)用了一個(gè) MSort() 函數(shù),因?yàn)槲覀円褂眠f歸調(diào)用,所以將 MSort() 封裝起來(lái)。

下面我們來(lái)看看MSort() 函數(shù):

function MSort(array &$arr,$start,$end){
  //當(dāng)子序列長(zhǎng)度為1時(shí),$start == $end,不用再分組
  if($start < $end){
    $mid = floor(($start + $end) / 2); //將 $arr 平分為 $arr[$start - $mid] 和 $arr[$mid+1 - $end]
    MSort($arr,$start,$mid);  //將 $arr[$start - $mid] 歸并為有序的$arr[$start - $mid]
    MSort($arr,$mid + 1,$end);  //將 $arr[$mid+1 - $end] 歸并為有序的 $arr[$mid+1 - $end]
    Merge($arr,$start,$mid,$end);    //將$arr[$start - $mid]部分和$arr[$mid+1 - $end]部分合并起來(lái)成為有序的$arr[$start - $end]
  }
}

上面的MSort() 函數(shù)實(shí)現(xiàn)將數(shù)組分半再分半(直到子序列長(zhǎng)度為1),然后將子序列合并起來(lái)。

現(xiàn)在是我們的歸并操作函數(shù)Merge() :

//歸并操作
function Merge(array &$arr,$start,$mid,$end){
  $i = $start;
  $j=$mid + 1;
  $k = $start;
  $temparr = array();
  while($i!=$mid+1 && $j!=$end+1)
  {
    if($arr[$i] >= $arr[$j]){
      $temparr[$k++] = $arr[$j++];
    }
    else{
      $temparr[$k++] = $arr[$i++];
    }
  }
  //將第一個(gè)子序列的剩余部分添加到已經(jīng)排好序的 $temparr 數(shù)組中
  while($i != $mid+1){
    $temparr[$k++] = $arr[$i++];
  }
  //將第二個(gè)子序列的剩余部分添加到已經(jīng)排好序的 $temparr 數(shù)組中
  while($j != $end+1){
    $temparr[$k++] = $arr[$j++];
  }
  for($i=$start; $i<=$end; $i++){
    $arr[$i] = $temparr[$i];
  }
}

到了這里,我們的歸并算法就完了。我們調(diào)用試試:

$arr = array(9,1,5,8,3,7,4,6,2);
MergeSort($arr);
var_dump($arr);

運(yùn)行結(jié)果:

array(9) {
 [0]=>
 int(1)
 [1]=>
 int(2)
 [2]=>
 int(3)
 [3]=>
 int(4)
 [4]=>
 int(5)
 [5]=>
 int(6)
 [6]=>
 int(7)
 [7]=>
 int(8)
 [8]=>
 int(9)
}

復(fù)雜度分析:

由于歸并算法無(wú)論原來(lái)的序列是否有序都會(huì)進(jìn)行分組和比較,因此它的好、最壞、平均的時(shí)間復(fù)雜度都是 O(nlogn)。

歸并算法是一種穩(wěn)定的排序算法。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“PHP排序算法中歸并排序Merging Sort的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司,,關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

當(dāng)前文章:PHP排序算法中歸并排序MergingSort的示例分析-創(chuàng)新互聯(lián)
當(dāng)前路徑:http://www.rwnh.cn/article14/ccioge.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供Google微信公眾號(hào)、定制網(wǎng)站自適應(yīng)網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站策劃

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
基隆市| 盐边县| 汤阴县| 云南省| 留坝县| 上犹县| 汤阴县| 岱山县| 神木县| 陇川县| 嘉义市| 石家庄市| 工布江达县| 万山特区| 旺苍县| 岗巴县| 霞浦县| 巴彦县| 岱山县| 桐梓县| 承德县| 平原县| 安溪县| 高邮市| 紫阳县| 神农架林区| 丹阳市| 普洱| 利津县| 蒲城县| 贵南县| 牟定县| 塔河县| 大悟县| 黎平县| 泽库县| 崇义县| 大理市| 安庆市| 鹿邑县| 莆田市|