婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP排序算法之歸并排序(Merging Sort)實例詳解

PHP排序算法之歸并排序(Merging Sort)實例詳解

熱門標簽:福建銀行智能外呼系統價格 電話機器人銷售主要負責什么 四川保險智能外呼系統供應商 長沙做地圖標注公司 上海做外呼線路的通信公司 地圖標注專員怎么樣 遼寧ai電銷機器人價格 寧波外呼營銷系統 房產中介用的是什么外呼系統

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

基本思想:

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

一、歸并的過程:

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

r 數組存儲排好序的 a 數組

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

二、歸并操作:

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

如 設有數列{6,202,100,301,38,8,1}

初始狀態:6 , 202 , 100 , 301 , 38 , 8,1

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

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

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

總的比較次數為:3+4+4=11,;

逆序數為14;

三、算法描述:

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

第一步:申請空間,使其大小為兩個已經排序序列之和,該空間用來存放合并后的序列

第二步:設定兩個指針,最初位置分別為兩個已經排序序列的起始位置

第三步:比較兩個指針所指向的元素,選擇相對小的元素放入到合并空間,并移動指針到下一位置

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

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

算法實現:

我們先來看看主函數部分:

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

在總函數中,我們只調用了一個 MSort() 函數,因為我們要使用遞歸調用,所以將 MSort() 封裝起來。

下面我們來看看 MSort() 函數:

function MSort(array $arr,$start,$end){
  //當子序列長度為1時,$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]部分合并起來成為有序的$arr[$start - $end]
  }
}

上面的 MSort() 函數實現將數組分半再分半(直到子序列長度為1),然后將子序列合并起來。

現在是我們的歸并操作函數 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++];
    }
  }
  //將第一個子序列的剩余部分添加到已經排好序的 $temparr 數組中
  while($i != $mid+1){
    $temparr[$k++] = $arr[$i++];
  }
  //將第二個子序列的剩余部分添加到已經排好序的 $temparr 數組中
  while($j != $end+1){
    $temparr[$k++] = $arr[$j++];
  }
  for($i=$start; $i=$end; $i++){
    $arr[$i] = $temparr[$i];
  }
}

到了這里,我們的歸并算法就完了。我們調用試試:

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

運行結果:

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)
}


復雜度分析:

由于歸并算法無論原來的序列是否有序都會進行分組和比較,因此它的最好、最壞、平均的時間復雜度都是 O(nlogn)

歸并算法是一種穩定的排序算法。

本文參考自《大話數據結構》,在此僅作記錄,方便以后查閱,大神勿噴!

PS:這里再為大家推薦一款關于排序的演示工具供大家參考:

在線動畫演示插入/選擇/冒泡/歸并/希爾/快速排序算法過程工具:
http://tools.jb51.net/aideddesign/paixu_ys

更多關于PHP相關內容感興趣的讀者可查看本站專題:《php排序算法總結》、《PHP數據結構與算法教程》、《php程序設計算法總結》、《php字符串(string)用法總結》、《PHP數組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結》及《PHP數學運算技巧總結》

希望本文所述對大家PHP程序設計有所幫助。

您可能感興趣的文章:
  • PHP排序算法之快速排序(Quick Sort)及其優化算法詳解
  • PHP排序算法之基數排序(Radix Sort)實例詳解
  • PHP排序算法之堆排序(Heap Sort)實例詳解
  • PHP排序算法之希爾排序(Shell Sort)實例分析
  • PHP排序算法之直接插入排序(Straight Insertion Sort)實例分析
  • PHP排序算法之簡單選擇排序(Simple Selection Sort)實例分析
  • php中sort函數排序知識點總結

標簽:宿遷 常德 深圳 澳門 佛山 工商登記 宜春 延安

巨人網絡通訊聲明:本文標題《PHP排序算法之歸并排序(Merging Sort)實例詳解》,本文關鍵詞  PHP,排序,算法,之,歸并,Merging,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP排序算法之歸并排序(Merging Sort)實例詳解》相關的同類信息!
  • 本頁收集關于PHP排序算法之歸并排序(Merging Sort)實例詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    一区二区三区在线观看视频| 久久九九全国免费| 2021久久国产精品不只是精品| 国产精品青草久久| 久久精品国产第一区二区三区| 色综合天天性综合| 69久久99精品久久久久婷婷| 日韩欧美亚洲另类制服综合在线| 日韩欧美一区二区视频| 一区二区三国产精华液| 成人精品国产免费网站| 久久精品人人做人人综合| 免费高清不卡av| 日韩欧美国产不卡| 天天色综合天天| 在线不卡的av| 久久精品999| 欧美日韩电影一区| 肉色丝袜一区二区| 久久久777精品电影网影网 | 91一区二区三区在线观看| 中文字幕在线不卡一区二区三区| av电影在线观看完整版一区二区| 久久精品人人做人人爽人人| 99r精品视频| 日本不卡不码高清免费观看| 精品久久99ma| 成人国产电影网| 久久久久久亚洲综合| 免费高清在线视频一区·| 亚洲精品一线二线三线| 91精品午夜视频| 欧美日本国产视频| 一本一本大道香蕉久在线精品| 国产盗摄女厕一区二区三区| 天天综合色天天综合| 1区2区3区精品视频| 国产亚洲欧美日韩在线一区| 日韩精品一区二区三区在线播放| 欧美日韩成人综合在线一区二区| 成人午夜电影久久影院| 国产伦精品一区二区三区免费迷| 久久精品999| 奇米四色…亚洲| 国产一区在线精品| 国产成人精品影视| 99热99精品| 欧美三级日韩三级| 91精品国产综合久久久蜜臀粉嫩| 欧美一区二区三区日韩视频| 欧美一级高清片| 国产日韩欧美精品一区| 亚洲视频在线一区二区| 一区二区三区精品视频在线| 午夜伦欧美伦电影理论片| 久久国产精品99久久久久久老狼 | 色菇凉天天综合网| 欧美精品自拍偷拍| 国产欧美精品一区aⅴ影院 | 中文字幕一区二区三区四区| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲成人三级小说| 国产在线一区观看| 91国产免费观看| 亚洲欧美日韩国产中文在线| 久久精品人人做人人综合| 亚洲精品国产一区二区精华液 | 中文字幕亚洲综合久久菠萝蜜| 亚洲电影激情视频网站| 成人av免费在线播放| 精品国产99国产精品| 国产精品无遮挡| 麻豆精品在线看| 日韩一卡二卡三卡四卡| 亚洲一区日韩精品中文字幕| 婷婷亚洲久悠悠色悠在线播放 | 1024亚洲合集| 国产精品自拍网站| 6080午夜不卡| 麻豆精品在线观看| 日韩欧美二区三区| 日本最新不卡在线| 欧美精品亚洲二区| 亚洲18女电影在线观看| 欧美人狂配大交3d怪物一区| 一区二区三区在线视频免费| 一本在线高清不卡dvd| 亚洲综合色成人| 欧美亚洲一区三区| 蜜桃久久久久久| 国产精品丝袜黑色高跟| 免费成人你懂的| 国产亚洲欧洲997久久综合| 粉嫩一区二区三区性色av| 国产精品久久久久久亚洲毛片 | av一二三不卡影片| 亚洲人成影院在线观看| 欧美一卡在线观看| 99久久精品免费| 午夜国产精品一区| 国产精品日产欧美久久久久| www.成人网.com| 日本中文字幕一区二区有限公司| 久久精品一二三| 欧美一卡2卡3卡4卡| 一本大道久久a久久精品综合| 青青草国产精品亚洲专区无| 国产精品国产精品国产专区不蜜| 69av一区二区三区| 色欧美88888久久久久久影院| 九一九一国产精品| 亚洲综合精品久久| 中文字幕高清一区| 日韩欧美国产电影| 精品视频在线看| 欧美三级资源在线| 97久久久精品综合88久久| 国产一区二区剧情av在线| 久久精品国产一区二区三| 亚洲va在线va天堂| 日韩av不卡一区二区| 青青草国产精品亚洲专区无| 亚洲123区在线观看| 日韩影院精彩在线| 麻豆精品在线看| 激情偷乱视频一区二区三区| 韩国欧美一区二区| 成人永久aaa| 欧洲精品一区二区| 欧美精品99久久久**| 日韩女优av电影| ...av二区三区久久精品| 一区二区三区色| 日韩一区精品视频| 久色婷婷小香蕉久久| 日韩高清在线电影| 国产成人免费视频| 在线观看一区二区视频| 欧美一区二区三区视频在线观看| 日韩欧美一级片| 亚洲自拍与偷拍| 精品一区二区在线视频| 粗大黑人巨茎大战欧美成人| 色香蕉成人二区免费| 久久久久久久久97黄色工厂| 亚洲欧美日韩国产成人精品影院| 日韩av中文在线观看| 色婷婷久久99综合精品jk白丝| 欧美日韩久久久| 久久久国产精华| 午夜精品福利一区二区三区av | 亚洲蜜臀av乱码久久精品| 韩国视频一区二区| 日韩亚洲欧美成人一区| 综合激情成人伊人| 99在线精品视频| 久久蜜臀精品av| 日韩国产精品久久| 在线免费观看日本一区| 亚洲同性同志一二三专区| 国产精品一区二区三区网站| 久久久亚洲午夜电影| 国产一区二区三区电影在线观看| 欧美日本在线观看| 美女网站一区二区| 欧美日韩成人在线一区| 亚洲国产精品久久久久秋霞影院 | 日韩福利视频导航| 911精品国产一区二区在线| 欧美aⅴ一区二区三区视频| 欧美一级久久久| 国产成人啪午夜精品网站男同| 久久久久国产精品人| 99热精品一区二区| 中文天堂在线一区| 欧美午夜精品久久久久久超碰| 蜜桃视频免费观看一区| 国产午夜精品福利| 欧美视频第二页| 国产麻豆精品视频| 亚洲精品美腿丝袜| 日韩欧美你懂的| 成人午夜精品一区二区三区| 日韩理论在线观看| 亚洲精品一区二区三区福利| 一本久久综合亚洲鲁鲁五月天| 蜜桃久久久久久久| 亚洲一区中文日韩| 久久精品一区二区三区四区| 欧美老肥妇做.爰bbww视频| 成a人片国产精品| 久久精品国产77777蜜臀| 一区二区三区在线视频播放| 久久中文字幕电影| 7777精品久久久大香线蕉| 欧美视频中文一区二区三区在线观看| 久久不见久久见中文字幕免费| 亚洲午夜免费视频| 亚洲成人免费视频|