校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁(yè) > 知識(shí)庫(kù) > PHP排序算法之歸并排序(Merging Sort)實(shí)例詳解

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

熱門標(biāo)簽:福建銀行智能外呼系統(tǒng)價(jià)格 電話機(jī)器人銷售主要負(fù)責(zé)什么 四川保險(xiǎn)智能外呼系統(tǒng)供應(yīng)商 長(zhǎng)沙做地圖標(biāo)注公司 上海做外呼線路的通信公司 地圖標(biāo)注專員怎么樣 遼寧ai電銷機(jī)器人價(jià)格 寧波外呼營(yíng)銷系統(tǒng) 房產(chǎn)中介用的是什么外呼系統(tǒng)

本文實(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ù)制到合并序列尾

算法實(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)定的排序算法。

本文參考自《大話數(shù)據(jù)結(jié)構(gòu)》,在此僅作記錄,方便以后查閱,大神勿噴!

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

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

更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php排序算法總結(jié)》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設(shè)計(jì)算法總結(jié)》、《php字符串(string)用法總結(jié)》、《PHP數(shù)組(Array)操作技巧大全》、《PHP常用遍歷算法與技巧總結(jié)》及《PHP數(shù)學(xué)運(yùn)算技巧總結(jié)》

希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。

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

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

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP排序算法之歸并排序(Merging Sort)實(shí)例詳解》,本文關(guān)鍵詞  PHP,排序,算法,之,歸并,Merging,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP排序算法之歸并排序(Merging Sort)實(shí)例詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP排序算法之歸并排序(Merging Sort)實(shí)例詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    97精品国产露脸对白| 精品国产99国产精品| 欧美日韩高清一区二区三区| 亚洲精品中文字幕乱码三区| 91国偷自产一区二区三区成为亚洲经典 | 欧美视频一区二区| 亚洲成人一区在线| 久久久夜色精品亚洲| 91色.com| 精品中文字幕一区二区小辣椒| 欧美激情在线免费观看| 日本精品免费观看高清观看| 极品少妇xxxx精品少妇| 一区二区三区中文字幕电影| 精品久久久久久久久久久久久久久| 成人app在线观看| 久久国产精品99久久人人澡| 一区二区三区美女视频| 欧美精品一区二区久久婷婷| 日本福利一区二区| 国产不卡高清在线观看视频| 午夜精品一区二区三区免费视频| 国产色产综合产在线视频| 欧美乱妇20p| 91原创在线视频| 极品少妇xxxx偷拍精品少妇| 偷窥少妇高潮呻吟av久久免费| 国产偷国产偷亚洲高清人白洁| 欧美另类z0zxhd电影| www.亚洲色图| 国产露脸91国语对白| 日韩黄色免费电影| 亚洲一区二区三区四区中文字幕 | 欧美三区免费完整视频在线观看| 国模娜娜一区二区三区| 日韩精品成人一区二区三区| 中文字幕一区在线| 中文字幕av资源一区| 久久久久9999亚洲精品| 欧美成人欧美edvon| 日韩三级伦理片妻子的秘密按摩| 欧美伊人久久久久久午夜久久久久| 成人天堂资源www在线| 国模冰冰炮一区二区| 激情综合色丁香一区二区| 日韩国产精品久久久| 亚洲gay无套男同| 亚洲成人激情自拍| 香蕉加勒比综合久久| 亚洲r级在线视频| 婷婷六月综合网| 日本欧美一区二区三区| 日本美女视频一区二区| 婷婷丁香久久五月婷婷| 午夜久久福利影院| 日韩成人伦理电影在线观看| 日韩av中文字幕一区二区| 免费成人结看片| 黄色日韩网站视频| 丁香六月久久综合狠狠色| 国产suv精品一区二区6| fc2成人免费人成在线观看播放| 成人久久18免费网站麻豆| 99视频一区二区三区| 欧美性生交片4| 精品欧美乱码久久久久久 | 91精品国产综合久久久久久| 欧美久久久影院| 日韩亚洲欧美高清| 国产亚洲va综合人人澡精品| 国产精品乱人伦中文| 亚洲欧美色图小说| 亚洲成人午夜电影| 国产麻豆91精品| 成人精品免费看| 欧美午夜理伦三级在线观看| 欧美精品乱码久久久久久按摩| 日韩午夜在线观看视频| 国产拍揄自揄精品视频麻豆| 亚洲美女电影在线| 激情图片小说一区| 色菇凉天天综合网| 日韩欧美精品三级| 国产精品视频九色porn| 亚洲成年人影院| 国产不卡一区视频| 欧美一区二区在线播放| 中文字幕一区二区三中文字幕| 亚洲国产精品精华液网站| 日本美女视频一区二区| 国产成人超碰人人澡人人澡| 欧美最猛黑人xxxxx猛交| 国产午夜精品久久久久久免费视| 亚洲黄色片在线观看| 国产一二三精品| 精品婷婷伊人一区三区三| 国产日产欧美一区| 蜜臀国产一区二区三区在线播放| 99久久精品免费看| 国产视频在线观看一区二区三区| 性做久久久久久久久| 色综合久久久久久久| 国产精品视频线看| 国产美女一区二区| 欧美成人一区二区三区| 亚洲香肠在线观看| 91亚洲永久精品| 久久色视频免费观看| 日韩电影网1区2区| 欧美剧在线免费观看网站| 亚洲欧美日本韩国| 北岛玲一区二区三区四区| 久久精品综合网| 国产一区免费电影| 久久午夜色播影院免费高清| 青青草原综合久久大伊人精品优势| 日本韩国一区二区| 一区二区三区四区不卡在线| 成人午夜精品在线| 中文字幕在线一区免费| 国产suv精品一区二区883| 国产欧美精品一区| 国产精品一区一区| 国产三级欧美三级日产三级99| 精品一区二区免费| 久久蜜桃一区二区| 国产河南妇女毛片精品久久久| 精品国产乱码久久| 久久久久久免费网| 国产一区二三区| 久久久无码精品亚洲日韩按摩| 亚洲午夜一二三区视频| 欧亚洲嫩模精品一区三区| 午夜精品福利一区二区三区蜜桃| 91麻豆精品在线观看| 亚洲日本丝袜连裤袜办公室| 91美女精品福利| 亚洲一级在线观看| 欧美男生操女生| 日韩成人精品在线| 欧美一区二区三区视频免费播放 | 韩国三级在线一区| 久久综合色之久久综合| 黄色资源网久久资源365| 日韩欧美中文一区二区| 男人的天堂久久精品| 日韩视频123| 激情综合色丁香一区二区| 欧美xingq一区二区| 99久久免费国产| 亚洲一区二区在线免费看| 欧美日韩aaaaaa| 久久不见久久见免费视频7| 国产亚洲精品超碰| 欧美丝袜自拍制服另类| 久久精品国产一区二区| 国产精品久久久久久久久动漫| 色婷婷综合视频在线观看| 日本免费在线视频不卡一不卡二| 久久久天堂av| 色中色一区二区| 美女一区二区视频| **欧美大码日韩| 日韩一区二区不卡| 成人少妇影院yyyy| 婷婷丁香激情综合| 亚洲精品乱码久久久久久日本蜜臀| 国产亚洲欧美日韩俺去了| 99riav久久精品riav| 日韩电影在线看| 国产欧美一区二区精品忘忧草| 91污片在线观看| 男人的j进女人的j一区| 中文字幕一区二区三区视频| 欧美精品久久天天躁| 成人黄色小视频在线观看| 日韩成人一级大片| 亚洲蜜桃精久久久久久久| 日韩三级.com| 色综合一个色综合| 国产激情91久久精品导航| 日韩va欧美va亚洲va久久| 国产精品美女久久久久久久| 欧美精选在线播放| 91视频.com| 国产在线播放一区| 成人美女视频在线看| 欧美不卡在线视频| 欧美三级电影精品| 欧美日韩一本到| 国产欧美精品一区二区三区四区 | 欧洲一区在线观看| 91精品国产一区二区三区香蕉| 亚洲va天堂va国产va久| 欧美刺激午夜性久久久久久久| 毛片一区二区三区| 在线观看91av| 88在线观看91蜜桃国自产| 韩日欧美一区二区三区| 久久亚洲欧美国产精品乐播|