国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C > 正文

歸并排序的遞歸實現與非遞歸實現代碼

2020-01-26 15:55:36
字體:
來源:轉載
供稿:網友

歸并排序
歸并排序是建立在歸并操作上的一種有效的排序算法。該算法是采用分治法(Divide and Conquer)的一個非常典型的應用。值得注意的是歸并排序是一種穩定的排序方法。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為2-路歸并。

算法描述
歸并操作的工作原理如下:
第一步:申請空間,使其大小為兩個已經排序序列之和,該空間用來存放合并后的序列
第二步:設定兩個指針,最初位置分別為兩個已經排序序列的起始位置
第三步:比較兩個指針所指向的元素,選擇相對小的元素放入到合并空間,并移動指針到下一位置

時間復雜度:
時間復雜度為O(nlogn) 這是該算法中最好、最壞和平均的時間性能。
空間復雜度為 O(n)
比較操作的次數介于(nlogn) / 2和nlogn - n + 1。
賦值操作的次數是(2nlogn)。歸并算法的空間復雜度為:0 (n)
歸并排序比較占用內存,但卻效率高且穩定的算法。
(以上摘抄自百度百科)

代碼實現
自頂向上實現:
//使用輔助數組實現歸并的過程

復制代碼 代碼如下:

void MergeSort(int *aux, int *data, int l, int m, int h)
{
 int k=0, i=l, j=m+1;

 for(k=l; k<=h; k++)
 {
  if(i>m)     aux[k]=data[j++];
  else if(j>h)    aux[k]=data[i++];
  else if(data[i]<data[j])        aux[k]=data[i++];
  else    aux[k]=data[j++];
 }
 for(k=l; k<=h; k++)
  data[k]=aux[k];
}

用遞歸實現排序的過程(自頂向下歸并)
復制代碼 代碼如下:

void Sort(int *aux, int *data, int l, int h)
{
 if(l<h)
 {
  int m=l+(h-l)/2;
  Sort(aux, data, l, m);
  Sort(aux, data, m+1, h);
  MergeSort(aux,data, l, m, h);
 }
}

用非遞歸實現排序的過程(自底向上歸并)
復制代碼 代碼如下:

void NonRerMerSort(int *aux, int *data, int l, int h)
{
 int i=l, j;
 for(i=l; i<=h; i=2*i)
 {
  for(j=l; j<=h-i; j+=2*i)
   MergeSort(aux, data, j, i+j-1, Min(j+2*i-1,h));
 }
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 深州市| 渭南市| 乡宁县| 沂南县| 潍坊市| 金溪县| 兴宁市| 衢州市| 孟州市| 白山市| 嘉定区| 喀喇| 宜兰市| 开江县| 诏安县| 南漳县| 上蔡县| 洪雅县| 田林县| 三门峡市| 余干县| 磴口县| 余庆县| 隆化县| 资源县| 新郑市| 蒲城县| 天峻县| 吕梁市| 阿坝| 图木舒克市| 沙湾县| 平凉市| 肃南| 深水埗区| 湄潭县| 丹凤县| 剑河县| 江阴市| 宁乡县| 江北区|