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

首頁 > 編程 > C > 正文

詳解C語言實(shí)現(xiàn)排序算法的介紹

2020-02-24 14:29:04
字體:
供稿:網(wǎng)友

排序算法中的合并排序采用合并技術(shù)進(jìn)行排序,合并是指將幾個(gè)已排序的子文件合并到一個(gè)有序文件中,本文是詳解C語言實(shí)現(xiàn)排序算法的介紹,一起跟著武林技術(shù)頻道小編的步伐來了解吧!

一、實(shí)現(xiàn)原理:

1、算法基本思路

設(shè)兩個(gè)有序的子文件(相當(dāng)于輸入堆)放在同一向量中相鄰的位置上:R[low..m],R[m+1..high],先將它們合并到一個(gè)局部的暫存向量R1(相當(dāng)于輸出堆)中,待合并完成后將R1復(fù)制回R[low..high]中。

(1)合并過程

合并過程中,設(shè)置i,j和p三個(gè)指針,其初值分別指向這三個(gè)記錄區(qū)的起始位置。合并時(shí)依次比較R[i]和R[j]的關(guān)鍵字,取關(guān)鍵字較小的記錄復(fù)制到R1[p]中,然后將被復(fù)制記錄的指針i或j加1,以及指向復(fù)制位置的指針p加1。
重復(fù)這一過程直至兩個(gè)輸入的子文件有一個(gè)已全部復(fù)制完畢(不妨稱其為空),此時(shí)將另一非空的子文件中剩余記錄依次復(fù)制到R1中即可。
最后,將結(jié)果賦值的R[]中。

(2)動(dòng)態(tài)申請(qǐng)R1

實(shí)現(xiàn)時(shí),R1是動(dòng)態(tài)申請(qǐng)的,因?yàn)樯暾?qǐng)的空間可能很大,故須加入申請(qǐng)空間是否成功的處理。

二、3種方法實(shí)現(xiàn):

算法1:歸并函數(shù)都動(dòng)態(tài)分配一個(gè)數(shù)組,兩個(gè)有序數(shù)組合并成一個(gè)有序數(shù)組

//合并將兩個(gè)有序序列([low,mid],[mid+1,high])合并void Merge(int arr[],int low,int mid,int high){  int i=low,j=mid+1,p=0;  int *newarr = (int *)malloc((high-low+1)*sizeof(int));//用來暫存排序好的數(shù)據(jù)  if(!newarr){    printf("malloc error!/n");    exit(1);  }  while(i<=mid && j<=high){    //以下過程很類似兩個(gè)有序字符串合并成一個(gè)有序字符串    if(arr[i] < arr[j])      newarr[p++] = arr[i++];    else      newarr[p++] = arr[j++];  }  while(i<=mid)    newarr[p++] = arr[i++];  while(j<=high)    newarr[p++] = arr[j++];  for(i=low,p=0;p<(high-low+1);i++,p++)  //將結(jié)果復(fù)制到原數(shù)組當(dāng)中    arr[i] = newarr[p];  free(newarr);}

算法2:

程序開始處就動(dòng)態(tài)分配一個(gè)大數(shù)組,避免每次都要?jiǎng)?chuàng)建很多小數(shù)組,釋放內(nèi)存的時(shí)候,不會(huì)立即釋放。

有關(guān)assert()參見:http://www.49028c.com/article/39685.htm

/* * File: mergesort.c * Time: 2014-07-19 HJJ */#include <stdio.h>#include <stdlib.h>#include <assert.h>static void merge1(int array[], int tmp[], int lpos, int rpos, int rend);static void msort1(int array[], int tmp[], int left, int right);void merge_sort1(int array[], int n){ assert(array!=NULL && n>1); //條件不滿足,退出程序并打印錯(cuò)誤語句。 int *tmp = (int *)malloc(sizeof(int) * n); assert(tmp != NULL); int i; for (i = 0; i < n; i ++) { tmp[i] = array[i]; } msort1(array, tmp, 0, n-1); free(tmp);}//遞歸的調(diào)用此函數(shù),實(shí)現(xiàn)折半劃分,只完成劃分,不實(shí)現(xiàn)排序,最終返回array[]數(shù)組有序static void msort1(int array[], int tmp[], int left, int right){ assert(array!=NULL && tmp!=NULL); if (left == right) return; int center = (left + right) / 2; msort1(tmp, array, left, center); msort1(tmp, array, center+1, right); merge1(tmp, array, left, center+1, right);}//該函數(shù)實(shí)現(xiàn),將array[]的左右兩半排好序的數(shù)組,歸并為tmp[],并排序static void merge1(int array[], int tmp[], int lpos, int rpos, int rend){ assert(array!=NULL && tmp!=NULL); int lend = rpos - 1; int tmp_pos = lpos; while (lpos<=lend && rpos<=rend) { if (array[lpos] <= array[rpos])  tmp[tmp_pos++] = array[lpos++]; else  tmp[tmp_pos++] = array[rpos++]; } while (lpos <= lend) tmp[tmp_pos++] = array[lpos++]; while (rpos <= rend) tmp[tmp_pos++] = array[rpos++];}int main(int argc, char *argv[]){  int a[7] = {6, 5, 4, 3, 2, 1, 7};  merge_sort1(a, 7);  int i;  for (i = 0; i < 7; i ++) {    printf("%3d", a[i]);  }  printf("/n");  return 0;}

算法3:
程序開始處分配一個(gè)大的數(shù)組,只是每次用array[]將數(shù)據(jù)給tmp[]排好序后,最后再將tmp[]給array[]賦值,這樣就能完成每次調(diào)用的時(shí)候,入口都一樣。

void merge_sort1(int array[], int n){ assert(array!=NULL && n>1); //條件不滿足,退出程序并打印錯(cuò)誤語句。 int *tmp = (int *)malloc(sizeof(int) * n); assert(tmp != NULL); int i; for (i = 0; i < n; i ++) { tmp[i] = array[i]; } msort1(array, tmp, 0, n-1); free(tmp);}//遞歸的調(diào)用此函數(shù),實(shí)現(xiàn)折半劃分,只完成劃分,不實(shí)現(xiàn)排序,最終返回array[]數(shù)組有序static void msort1(int array[], int tmp[], int left, int right){ assert(array!=NULL && tmp!=NULL); if (left == right) return; int center = (left + right) / 2; msort1(tmp, array, left, center); msort1(tmp, array, center+1, right); merge(tmp, array, left, center+1, right);}

實(shí)現(xiàn)方法二:

void merge(int array[],int tmp[],int lpos,int rpos,int rend){  int i,leftend,num,tmppos;  leftend = rpos - 1;  num = rend - lpos + 1;  tmppos = lpos;  while(lpos <= leftend && rpos <= rend){    if(array[lpos] <= array[rpos])      tmp[tmppos++] = array[lpos++];    else      tmp[tmppos++] = array[rpos++];  }  while(lpos <= leftend)    tmp[tmppos++] = array[lpos++];  while(rpos <= rend)    tmp[tmppos++] = array[rpos++];  for(i = 0;i < num;i++,rend--)    array[rend] = tmp[rend];}

歸并排序:將一個(gè)無序數(shù)組合并成一個(gè)有序數(shù)組

有兩種實(shí)現(xiàn)方法:自底向上和自頂向下

1、 自底向上的方法(自底向上的歸并排序算法雖然效率較高,但可讀性較差。)

(1) 自底向上的基本思想:

自底向上的基本思想是:第1趟歸并排序時(shí),將待排序的文件R[1..n]看作是n個(gè)長(zhǎng)度為1的有序子文件,將這些子文件兩兩歸并,若n為偶數(shù),則得到n/2個(gè)長(zhǎng)度為2的有序子文件;若n為奇數(shù),則最后一個(gè)子文件輪空(不參與歸并)。故本趟歸并完成后,前l(fā)ogn個(gè)有序子文件長(zhǎng)度為2,但最后一個(gè)子文件長(zhǎng)度仍為1;第2趟歸并則是將第1趟歸并所得到的logn個(gè)有序的子文件兩兩歸并,如此反復(fù),直到最后得到一個(gè)長(zhǎng)度為n的有序文件為止。
上述的每次歸并操作,均是將兩個(gè)有序的子文件合并成一個(gè)有序的子文件,故稱其為"二路歸并排序"。
類似地有k(k>2)路歸并排序。

(2) 一趟歸并算法
?分析:
在某趟歸并中,設(shè)各子文件長(zhǎng)度為length(最后一個(gè)子文件的長(zhǎng)度可能小于length),則歸并前R[1..n]中共有 個(gè)有序的子文件:R[1..length],R[length+1..2length],…

注意:

調(diào)用歸并操作將相鄰的一對(duì)子文件進(jìn)行歸并時(shí),必須對(duì)子文件的個(gè)數(shù)可能是奇數(shù)、以及最后一個(gè)子文件的長(zhǎng)度小于length這兩種特殊情況進(jìn)行特殊處理:

① 若子文件個(gè)數(shù)為奇數(shù),則最后一個(gè)子文件無須和其它子文件歸并(即本趟輪空);
② 若子文件個(gè)數(shù)為偶數(shù),則要注意最后一對(duì)子文件中后一子文件的區(qū)間上界是n。

具體算法如下:

/*自底向上,這里就不寫真正的代碼了,從網(wǎng)上copy了*/void MergePass(SeqList R,int length){ //對(duì)R[1..n]做一趟歸并排序  int i;  for(i=1;i+2*length-1<=n;i=i+2*length)    Merge(R,i,i+length-1,i+2*length-1);  //歸并長(zhǎng)度為length的兩個(gè)相鄰子文件  if(i+length-1<n) //尚有兩個(gè)子文件,其中后一個(gè)長(zhǎng)度小于length    Merge(R,i,i+length-1,n); //歸并最后兩個(gè)子文件//注意:若i≤n且i+length-1≥n時(shí),則剩余一個(gè)子文件輪空,無須歸并} //MergePassvoid MergeSort(SeqList R){//采用自底向上的方法,對(duì)R[1..n]進(jìn)行二路歸并排序  int length;  for(1ength=1;length<n;length*=2) //做 趟歸并    MergePass(R,length); //有序段長(zhǎng)度≥n時(shí)終止}

2、自頂向下的方法

采用分治法進(jìn)行自頂向下的算法設(shè)計(jì),形式更為簡(jiǎn)潔。

(1)分治法的三個(gè)步驟

設(shè)歸并排序的當(dāng)前區(qū)間是R[low..high],分治法的三個(gè)步驟是:

分解:將當(dāng)前區(qū)間一分為二,即求分裂點(diǎn):mid = (low+high)/2;
求解:遞歸地對(duì)兩個(gè)子區(qū)間R[low..mid]和R[mid+1..high]進(jìn)行歸并排序;
組合:將已排序的兩個(gè)子區(qū)間R[low..mid]和R[mid+1..high]歸并為一個(gè)有序的區(qū)間R[low..high]。

遞歸的終結(jié)條件:子區(qū)間長(zhǎng)度為1(一個(gè)記錄自然有序)。

具體算法:

void MSort(int arr[],int low,int high){  if(low < high){    int mid = (low+high)/2;    MSort(arr,low,mid);   //左半?yún)^(qū)排序    MSort(arr,mid+1,high); //右半?yún)^(qū)排序    Merge(arr,low,mid,high);//左右半?yún)^(qū)合并  }}

三:分析

1、穩(wěn)定性
歸并排序是一種穩(wěn)定的排序。

2、存儲(chǔ)結(jié)構(gòu)要求
可用順序存儲(chǔ)結(jié)構(gòu)。也易于在鏈表上實(shí)現(xiàn)。

3、時(shí)間復(fù)雜度
對(duì)長(zhǎng)度為n的文件,需進(jìn)行l(wèi)gn趟二路歸并,每趟歸并的時(shí)間為O(n),故其時(shí)間復(fù)雜度無論是在最好情況下還是在最壞情況下均是O(nlgn)。

4、空間復(fù)雜度
需要一個(gè)輔助向量來暫存兩有序子文件歸并的結(jié)果,故其輔助空間復(fù)雜度為O(n),顯然它不是就地排序。

注意:
若用單鏈表做存儲(chǔ)結(jié)構(gòu),很容易給出就地的歸并排序。

以上就是關(guān)于詳解C語言實(shí)現(xiàn)排序算法的介紹,相信這些知識(shí)能很好的幫助到你,如果你想選擇一個(gè)可靠的學(xué)習(xí)平臺(tái),你必須多方考察,武林技術(shù)頻道的網(wǎng)站能給你最好的幫助!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

麻豆成人av| 日批视频免费在线观看| 国产一区二区剧情av在线| 欧美午夜电影网| 看片网址国产福利av中文字幕| 免费裸体美女网站| 一二三区精品福利视频| 欧美电影一区二区三区| 天天干天天操天天做| 日韩一卡二卡在线| 亚洲av无码精品一区二区| 欧美性猛交xxxx免费看手交| 久久露脸国语精品国产91| 青青青青草视频| 精品亚洲成a人片在线观看| 欧美天堂在线观看| 国产va免费精品观看精品| 国产尤物视频在线观看| 中文字幕亚洲在线观看| 亚洲激情成人网| 99久久免费精品国产72精品九九| 一区二区三区在线视频观看58| 日韩和的一区二区| 精品福利视频导航大全| 日批视频免费观看| 男人插入女人视频| 欧美性高潮床叫视频| 色天使综合视频| 日韩成人综合网站| 久久婷婷国产综合精品青草| 中文字幕av一区二区三区人妻少妇| 天天影视综合色| mm1313亚洲国产精品美女| 国产一级久久| 特级西西www444人体聚色| 麻豆9191精品国产| 中国一级特黄录像播放| www.com国产| 欧美日韩一区二区三区视视频| 99综合在线| 国产精品久久久久久亚洲伦| 亚洲欧美自拍偷拍| 丰满人妻av一区二区三区| 91精品综合久久久久久久久久久| 青青操在线观看视频| 成人h小游戏| 久久久久久久av| 欧美激情图片区| 久久精品久久久精品美女| 精品美女在线观看| 国产精品久久a| 欧美日韩激情视频8区| 亚洲一区二区三区激情| 亚洲理论电影在线观看| 国产成人av影院| 外国成人激情视频| 久久亚洲不卡| 在线免费观看黄色av| 成人性生交大片免费看视频r| 国产一区二区av在线| av成人免费观看| 欧美在线观看18| 天天爽天天爽夜夜爽| aa成人免费视频| 久久精品国产久精国产| 欧美日韩国产综合久久| 国产精品免费入口| 国产日韩欧美一区在线| 波多野吉衣av| 久久99精品国产99久久| xx00欧美| 老司机深夜福利在线观看| 国产探花视频在线播放| 高清日韩电视剧大全免费| 成人精品在线视频| 久久精品色欧美aⅴ一区二区| 欧美一区二区视频在线观看2020| 日本三级亚洲精品| 日本不卡在线观看视频| 欧美禁忌电影| 成人网页在线免费观看| 青草国产精品| 加勒比成人在线| a级片在线观看| 午夜在线观看免费一区| 天堂精品高清1区2区3区| 天堂av2020| 国产免费一区二区三区免费视频| 国产www视频在线观看| 久青草国产在线| 日本a级片在线播放| 91色porny| 欧美日韩亚洲自拍| 户外极限露出调教在线视频| 秋霞电影网一区二区| av中文字幕在线免费观看| 人妻久久久一区二区三区| 在线国产精品视频| 中文字幕avav| 上原亚衣av一区二区三区| 精品影片在线观看的网站| 少妇一级淫免费观看| 日本三级韩国三级久久| 日本japanese极品少妇| 久久精品色播| 妞干网在线观看视频| 欧美在线制服丝袜| 哪个网站能看毛片| 欧美大黑bbbbbbbbb在线| 亚洲免费国产视频| 亚洲免费大片在线观看| 4hu四虎永久在线影院成人| 久久久久久久性| 成人精品一区二区三区电影免费| 午夜免费久久看| jizz免费观看| 国产美女91呻吟求| 91精品久久| 亚洲人成电影| h网站免费观看| 日韩欧美国产三级电影视频| 一区二区三区四区不卡视频| 91精品国产91热久久久做人人| 国产视频1区| 男人网站在线观看| 精品国产乱码久久久久| 性chinese极品按摩| 国产欧美一区二区精品性色| 成人www视频网站免费观看| 欧美日韩一区二区三区高清| 久久国产主播精品| 不卡中文字幕在线观看| 中文av资源| 欧美精品xxxxbbbb| 亚欧洲精品在线视频免费观看| 性欧美18~19sex高清播放| 国产精品麻豆久久| 午夜免费视频网站| 欧美日韩调教| 国产精品国产| 一区二区三区韩国| 国产精品chinese| 欧美在线aaa| 亚洲精品国产一区二| 日本高清不卡在线观看| 日韩精品乱码久久久久久| 秋霞午夜一区二区三区视频| 韩国一区二区在线播放| 国户精品久久久久久久久久久不卡| 国产噜噜噜噜久久久久久久久| 欧美国产日韩一区二区| 天天色av.com| 在线观看你懂| 久久一卡二卡| 亚洲欧美自拍视频| 午夜激情视频网| 黄色av电影在线播放| 国产精品**亚洲精品| 成年人黄视频在线观看| 懂色av粉嫩av蜜臀av一区二区三区| 日本色护士高潮视频在线观看| 天海翼一区二区三区免费| jizzjizz丝袜老师| 欧美日韩一级在线观看| 国产免费成人| 黄色片网址在线观看| 在线亚洲精品| wwwxx欧美| jizz久久久久久| 成人黄色网页| 欧美在线视频精品| 男人草女人视频| 一本久中文高清| 国产精品1区2区3区| 中文字幕成人在线观看| 婷婷精品进入| 日本xxx在线播放| 久久久久久亚洲精品杨幂换脸| 97在线观看| 久久艳妇乳肉豪妇荡乳av| 在线播放国产视频| 1234区中文字幕在线观看| 久久国产精品网站| v天堂中文在线| 精品一区91| www.xxx麻豆| 国产91一区二区三区| 午夜视频免费看| 人人干人人插| 亚洲一区在线视频观看| 日本dvd播放| 91精品国产乱码久久久久久久久| 筱崎爱全乳无删减在线观看| av永久免费观看| а√天堂资源地址在线下载| 熟女熟妇伦久久影院毛片一区二区| 伦一区二区三区中文字幕v亚洲| 亚洲成在线观看| 国产在线精选视频| 国产丰满美女做爰| 久久精品人妻一区二区三区| 亚洲AV无码成人精品区东京热| 91午夜视频在线观看| 国产精品网红直播| 香蕉久久夜色精品国产更新时间| 人妻熟妇乱又伦精品视频| 蜜臀av免费在线观看| 国产一区二区调教| 日本a级片在线播放| 日本青青草视频| 拍真实国产伦偷精品| 成人av电影在线观看| 推川ゆうり中文亚洲二区| 一区二区中文字| 日本少妇xxxx动漫| 亚洲人成电影在线播放| 美女精品视频| 日韩vs国产vs欧美| 亚洲欧洲性图库| 欧美女人交a| caopor在线| 亚洲欧美国产精品久久久久久久| 波多野结衣的一区二区三区| 97精品电影院| 国产+成+人+亚洲欧洲在线| 91麻豆精品一区二区三区| av免费中文字幕| 国产精品一区二区欧美黑人喷潮水| 久久91精品国产91久久小草| 国产精品久久久久久亚洲伦| 99久久精品免费观看| 蜜臀一区二区三区精品免费视频| 欧美1o一11sex性hdhd| 国产亚洲va综合人人澡精品| 亚洲二区在线观看| 成人午夜伦理影院| 欧美日韩免费区域视频在线观看| 亚洲成在人线免费观看| 日韩av在线中文| 亚洲国产精品久久久久婷婷老年| 99久久精品一区| 国产午夜视频在线播放| 国产精品视频一区二区久久| 在线观看的黄色| 涩涩av在线| 五月婷婷导航| 欧美精品中文字幕一区| 亚洲欧洲视频在线| 欧美最猛性xxxxx亚洲精品| 国产伦一区二区三区色一情| 欧美性极品videosbest| 91福利免费在线| 亚洲AV无码成人精品区明星换面| 国产精品久久久久久久久久辛辛| 亚洲区欧洲区| 久草热久草在线频| 粉嫩久久99精品久久久久久夜| 久久精品免费观看| 日本一区二区三区四区高清视频| 欧美二区在线播放| 欧美日韩五区| 天堂一区二区三区| 大桥未久av一区二区三区中文| 三级av免费观看| 亚洲二区免费| 在线观看亚洲网站| 丁香花在线高清完整版视频| 99精品免费在线观看| 中文字幕一区二区三区精品| 2019中文字幕在线观看| japanese在线播放| 日韩在线免费| 日韩中文字幕在线视频播放| 免费偷拍视频网站| 国产精品av一区二区三区| 亚洲狠狠婷婷综合久久久| 在线观看免费视频国产| 国产一区久久| 久播影院第一理论片| 日韩精品不卡一区二区| 在线观看国产精品日韩av| 欧美91在线|欧美| 日本人69视频| 精品人妻人人做人人爽夜夜爽| 狠狠人妻久久久久久综合蜜桃| 清纯唯美亚洲综合| 欧美尤物一区| 欧美日韩视频免费播放| 在线电影av| 免费成人高清在线视频| 佐佐木明希电影| 一区二区三区四区在线视频| jlzzjlzz亚洲日本少妇| 成看片vvv222| 亚洲精品国产一区二区三区四区在线| 欧美精品另类| 99久久人爽人人添人人澡| 久久99国产精品二区高清软件| 久久久久久国产精品| 麻豆国产精品va在线观看不卡| 久久夜色精品国产噜噜av小说| 天堂网www在线中文天堂| 国产亚洲aⅴaaaaaa毛片| 亚洲欧洲综合另类| 欧美大黑bbbbbbbbb在线| 国产黄色av网站| 国产成人精品网址| 亚洲精品手机在线观看| 亚洲男女性事视频| 成人亚洲一区| 国产在线视频欧美一区二区三区| 日本丰满少妇做爰爽爽| 欧美日韩国产精品一卡| 日韩一级精品视频在线观看| 国内精品福利| 亚洲欧美日本一区二区| 日韩av一二三四区| 久久视频在线免费观看| 3d动漫成人在线| 久久久夜色精品亚洲| 波多野吉衣在线视频| 午夜精品久久99蜜桃的功能介绍| 女女同性女同一区二区三区按摩| 日本午夜视频| 黄色网页在线观看| 黄色成人在线免费观看| 在线欧美一级视频| 欧美一区二区网站|