亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

手把手教你寫一個歸并排序

2019-11-10 20:26:34
字體:
來源:轉載
供稿:網友

歸并排序是一個很穩定的排序方法,它具有以下特點:  1.時間復雜度為θ(NlogN)(關于時間復雜度的符號表示可以查看《算法導論》第一部分第三/四章),穩定而且是比較排序模型中能達到的最快(當然就算換個很舒服的輸入也只能花同樣的時間) 2.它不是一個in place的排序算法。也就是說它的排序需要借助一個臨時數組來存放數據。

算法分析

歸并排序用的是分治法 眾所周知(強行眾所周知)分治法的三個步驟:拆分(母問題為子問題)-解決(子問題)-合并(子問題的解)。歸并排序的這三個步驟描述如下: 拆分:將數組拆為兩個子數組(盡量等分) 解決:將兩個子數組分別排序 合并:此處是歸并排序的重點部分,其思路是這樣的——首先創建一個足以容納下兩個數組的所有元素的數列用于儲存數據,然后對于兩個已經排好序的數列來說,比較其首元素,取小的一方填入新數列,隨后將新數列和剛處理的數列指針后移,然后如此往復,當某一個指針已經指向數組最后一個元素之后時,將另一個數組中的元素按順序填入新數組。 不難看出,如果兩子數列已經有序那么最后合并所得的數列一定是有序的。而當問題被遞歸式地拆分到底(bottom out)時,也就是只有一個元素之后,合并所做的只是將兩個元素按照大小順序填入一個新的只會有兩個元素的數組。

手把手教你寫代碼

這里就只說C啦,C++的也可以按著寫反正用到的還沒有那么多不同。 首先關于臨時數組我是這么想的:既然每次都會用到對應大小的數組,那么干脆就申請一個等大的數組用于排列,正好序號還能對得上。不過考慮到每次排序完成后是臨時數組變得有序,所以在排序之后還應有個復制的過程。 因為排序的時候有排序合并兩個操作,所以要有兩個函數。因為是自己用所以也不用關心越界/錯誤情況,所以返回值用void就好

#include <stdio.h>void mergesort(int *arr,int *tem,int begin,int end);void merge(int *arr,int *tem,int begin,int mid,int end);int main()//再次強調:你可以只寫main()但一定不要寫 void main()!{ int n,i; scanf("%d",&n); int arr[n],tem[n];//C99之后可以用變量作為容量申請數組了 mergesort(arr,tem,0,n-1); reutnr 0;}

主函數就完成了,現在我們開始考慮mergesort函數 傳入以后要判斷是不是已經到底了,如果到底我們是需要一個復制的過程,之后會需要遞歸排序,最后用合并函數。 于是mergesort函數寫成這樣:

void mergesort(int *arr,int *tem,int begin,int end){ if(begin<end){ int mid=(begin+end)>>1; mergesort(arr,tem,begin,mid); mergesort(arr,tem,mid+1,end); merge(arr,tem,begin,mid,end); }else{ tem[begin]=arr[begin]; }}

現在可以開始merge函數的編寫了,這也是我認為的歸并排序最難的地方,我理出來的思路是這樣的: 因為最后是有一個復制的過程的,所以指針在開始的時候是不能變的,那么就在開始申請變量賦值用于開始的排序就好。 int *p1=tem+first,*p2=tem+mid+1,*p3=arr+first; 對于是否滿足放入數組的條件我一開始寫成這樣:

if((p1<tem+mid+1)&&(*p1<*p2))

錯在哪里? 注意如果p2都已經到末尾了(越界),這個壞東西還是會判斷后面的垃圾數據是不是滿足條件,而我們又都知道C語言的邏輯是存在短路這個東西的,所以最后merge函數應該長這樣:

void merge(int *arr,int *tem,int first,int mid,int last){ int *p1=tem+first,*p2=tem+mid+1,*p3=arr+first; int i; for(i=0;i<last-first+1;i++){ if((p2>tem+last)||(p1<tem+mid+1)&&(*p1<*p2)){ *(p3++)=*(p1++); }else{ *(p3++)=*(p2++); } }while(first<=last){ *(tem+first)=*(arr+first);//可別忘復制這個操作 first++; }}如果感覺自己明白了,不妨動手試一試寫一個自己的歸并排序吧~
上一篇:SAX解析XML

下一篇:P1996 約瑟夫問題

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲福利在线看| 一本色道久久综合狠狠躁篇的优点| 久久国产精品久久久久久久久久| 日本一区二区三区四区视频| 精品激情国产视频| www.亚洲男人天堂| 久久精品久久久久电影| 亚洲精品短视频| 日本高清视频一区| 日韩在线观看免费av| 国产精品大陆在线观看| 久久99热精品这里久久精品| 成人两性免费视频| 欧美精品在线观看91| 国产精品普通话| 91亚洲国产成人精品性色| 欧美国产精品va在线观看| 久久久精品网站| 亚洲国产成人爱av在线播放| 欧美成人免费网| www.日韩系列| 欧美猛男性生活免费| 日韩中文字幕在线播放| 国产在线日韩在线| 66m—66摸成人免费视频| 九九九热精品免费视频观看网站| 国产午夜一区二区| 日韩av网站电影| 亚洲最大成人网色| 亚洲人成在线观看| 亚洲自拍偷拍视频| 久久综合久中文字幕青草| 91网在线免费观看| 成人免费自拍视频| 国产高清视频一区三区| 亚洲成人激情在线观看| 日韩免费av片在线观看| 欧美国产极速在线| 欧美肥臀大乳一区二区免费视频| 国产精品视频精品视频| 日韩性生活视频| 中文字幕亚洲综合久久筱田步美| 欧美性猛交99久久久久99按摩| 日本韩国欧美精品大片卡二| 中文精品99久久国产香蕉| 97成人精品区在线播放| 久久夜精品va视频免费观看| 久久久久99精品久久久久| 亚洲精品福利在线| 777精品视频| 久久激情视频久久| 国产成人精品一区二区在线| 日韩精品免费在线视频| 亚洲另类欧美自拍| 97精品在线视频| 91九色单男在线观看| 欧美一区第一页| 国产精品jvid在线观看蜜臀| 欧美老肥婆性猛交视频| 好吊成人免视频| 欧美激情中文字幕乱码免费| 久久免费视频网站| 欧美洲成人男女午夜视频| 亚洲成人激情视频| 国产成人综合av| 欧美激情视频给我| 亚洲欧美另类在线观看| 岛国视频午夜一区免费在线观看| 中文字幕欧美专区| 国产午夜精品一区理论片飘花| 懂色aⅴ精品一区二区三区蜜月| 国产日韩欧美黄色| 久久久视频精品| 欧美国产日韩一区二区| 欧美日韩视频在线| 精品国产一区二区三区四区在线观看| 久久激情视频久久| 日韩欧美在线第一页| 国产mv免费观看入口亚洲| 欧美激情视频一区| 国产亚洲福利一区| 高清一区二区三区日本久| 日韩精品免费在线观看| 亚洲一区中文字幕| 国产成人精品av| 亚洲第一福利在线观看| 久久精品99国产精品酒店日本| 中文字幕亚洲欧美日韩高清| 久久精品中文字幕免费mv| 成人在线精品视频| 国产精品美女主播| 黄色成人在线免费| 国产精品成人一区| 亚洲国产婷婷香蕉久久久久久| 亚洲男人的天堂在线| 尤物九九久久国产精品的特点| 亚洲人成电影在线播放| 日本19禁啪啪免费观看www| 日韩网站免费观看高清| 久久国产精品电影| 精品国产户外野外| 亚洲免费av电影| 国产专区欧美专区| 国产精品老牛影院在线观看| 日本一区二三区好的精华液| 亚洲人成网站777色婷婷| 日韩在线视频观看| 久久久av亚洲男天堂| 国产成人精品午夜| 欧美黑人性猛交| 久久69精品久久久久久国产越南| 日本在线观看天堂男亚洲| 国产精品狠色婷| 精品在线观看国产| 国产精品一久久香蕉国产线看观看| 在线视频欧美性高潮| 亚洲美女精品成人在线视频| 国产精品福利在线观看| 中文字幕亚洲国产| 欧美精品生活片| 欧美成人精品一区二区三区| 久久网福利资源网站| 国产日韩欧美另类| 最近中文字幕mv在线一区二区三区四区| 欧美成人黄色小视频| 亚洲综合最新在线| 欧美老肥婆性猛交视频| 一区二区三区美女xx视频| 中文字幕亚洲欧美日韩高清| 亚洲欧洲国产一区| 日韩精品免费观看| 久久av红桃一区二区小说| 久久频这里精品99香蕉| 8x拔播拔播x8国产精品| 久久精品99无色码中文字幕| 欧美视频中文字幕在线| 欧美日韩亚洲激情| 日本精品一区二区三区在线播放视频| 精品国偷自产在线视频99| 九九热这里只有精品免费看| 日韩亚洲第一页| 欧美日韩中国免费专区在线看| 2021国产精品视频| 亚洲一区二区三区sesese| 国产不卡精品视男人的天堂| 97在线精品国自产拍中文| 国产成人激情小视频| 色偷偷偷亚洲综合网另类| 欧美日韩在线视频首页| 一级做a爰片久久毛片美女图片| 中文字幕精品在线视频| 欧美肥老妇视频| 午夜免费在线观看精品视频| 91免费电影网站| 国产精品国语对白| 亚洲一区国产精品| 一个人看的www久久| 国产精品三级在线| 欧美在线观看网址综合| y97精品国产97久久久久久| 中文字幕亚洲二区| 91精品中文在线| 国自产精品手机在线观看视频| 国产日韩在线亚洲字幕中文|