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

首頁 > 編程 > C++ > 正文

C++實現自底向上的歸并排序算法

2020-01-26 14:47:48
字體:
來源:轉載
供稿:網友

本文實例講述了C++實現自底向上的歸并排序算法。分享給大家供大家參考,具體如下:

一. 算法描述

自底向上的歸并排序:歸并排序主要是完成將若干個有序子序列合并成一個完整的有序子序列;自底向上的排序是歸并排序的一種實現方式,將一個無序的N長數組切個成N個有序子序列,然后再兩兩合并,然后再將合并后的N/2(或者N/2 + 1)個子序列繼續進行兩兩合并,以此類推得到一個完整的有序數組。下圖詳細的分解了自底向上的合并算法的實現過程:

二. 算法實現

/*=============================================================================##   FileName:  mergeSort.c#   Algorithm: 歸并排序(自底向上)#   Author:   Knife#   Created:  2014-06-14 16:40:02#=============================================================================*/#include<stdio.h>#include<stdlib.h>void merge_sort(int* intArr, int intArr_len);void merge_array(int* intArr1, int len1, int* intArr2, int len2);void main(){  int intArr[] = {8,3,6,4,2,9,5,4,1,7};  int n = sizeof (intArr) / sizeof (intArr[0]);  int i = 0;  merge_sort(intArr, n);  for(;i<n;i++){    printf("%d ",intArr[i]);  }  printf("/n");}//歸并排序(自底向上)void merge_sort(int* intArr, int intArr_len){  int len = 1;  int k = 0;  while (len < intArr_len) {     int i = 0;     for (; i + 2*len <= intArr_len; i += 2*len){      int* intArr1 = intArr + i;      int intArr1_len = len;      int* intArr2 = intArr + i + len;      int intArr2_len = len;      merge_array(intArr1, intArr1_len, intArr2, intArr2_len);     }    if (i + len <= intArr_len){       int* intArr1 = intArr + i;      int intArr1_len = len;      int* intArr2 = intArr + i + len;      int intArr2_len = intArr_len - i - len;      merge_array( intArr1, intArr1_len, intArr2, intArr2_len);     }    len *= 2;  //有序子序列長度*2   } }//合并兩個數組,并排序void merge_array(int* intArr1, int len1, int* intArr2, int len2){  //申請分配空間  int* list = (int*) malloc((len1+len2) * sizeof (int));  int i = 0, j = 0, k = 0;  while(i < len1 && j < len2){     // 把較小的那個數據放到結果數組里, 同時移動指針    list[k++] = (intArr1[i] < intArr2[j]) ? intArr1[i++] : intArr2[j++];  }  // 如果 intArr1 還有元素,把剩下的數據直接放到結果數組  while(i < len1){    list[k++] = intArr1[i++];  }  // 如果 intArr2 還有元素,把剩下的數據直接放到結果數組  while(j < len2){    list[k++] = intArr2[j++];  }   // 把結果數組 copy 到 intArr1 里  for(i = 0; i < k; i++){    intArr1[i] = list[i];  }  //釋放申請的空間  free(list);}

三. 算法分析

平均時間復雜度:O(nlog2n)
空間復雜度:O(n)  (用于存儲有序子序列合并后有序序列)
穩定性:穩定

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美精品网站| 日韩一区二区三区国产| 亚洲跨种族黑人xxx| 久久成人av网站| 国产日韩在线看| 久久91亚洲精品中文字幕| 国产亚洲精品久久久久久牛牛| 国产深夜精品福利| 欧美美女15p| 色偷偷av一区二区三区乱| 国产成人精品一区二区| 亚洲第一精品福利| 亚洲自拍小视频免费观看| 欧美日韩福利视频| 国产亚洲精品成人av久久ww| 欧美日韩国产123| 国产91在线播放九色快色| 日韩高清电影好看的电视剧电影| 色婷婷亚洲mv天堂mv在影片| 成人免费看黄网站| 亚洲欧美日韩国产成人| 国产精品18久久久久久首页狼| 欧美性高潮在线| 午夜精品久久久久久久久久久久| 欧美精品videossex88| 欧美日韩国产综合新一区| 中文字幕日本欧美| 亚洲天堂av在线播放| 亚洲偷欧美偷国内偷| 国产91精品黑色丝袜高跟鞋| 国产大片精品免费永久看nba| 欧美做爰性生交视频| 久久人人爽人人爽人人片亚洲| 91亚洲国产成人久久精品网站| 亚洲第一区中文99精品| 伊人久久久久久久久久久久久| 奇米一区二区三区四区久久| 国产91对白在线播放| 欧美一区在线直播| 日韩av在线看| 一区二区三区高清国产| 青青草99啪国产免费| 91老司机精品视频| 日韩国产精品亚洲а∨天堂免| 亚洲欧美精品一区二区| 亚洲国产精品电影在线观看| 欧美一区二区三区……| 日韩国产一区三区| 欧美韩国理论所午夜片917电影| 中文字幕亚洲欧美日韩高清| 在线亚洲国产精品网| 日韩在线免费视频观看| 欧美日韩福利在线观看| 国产精品xxxxx| www.日韩系列| 国产精品日日做人人爱| 亚洲精品www| 亚洲欧洲日产国码av系列天堂| 国产午夜精品全部视频在线播放| www欧美日韩| 亚洲a∨日韩av高清在线观看| 欧美日韩国产二区| 中文字幕久热精品视频在线| 国外成人在线播放| 国产欧美日韩精品丝袜高跟鞋| 国产精品入口尤物| 欧美激情在线播放| 欧美日韩裸体免费视频| 国产欧美 在线欧美| 欧美性猛交xxxxx免费看| 久99久在线视频| 91精品久久久久久久久不口人| 日本免费一区二区三区视频观看| 国产一区二区三区中文| 51久久精品夜色国产麻豆| 亚洲人成网站免费播放| 国内精品一区二区三区四区| 51视频国产精品一区二区| 2019av中文字幕| 国产美女被下药99| 亚洲精品综合久久中文字幕| 国产精品视频免费在线观看| 欧美高清视频一区二区| 欧美精品videossex88| 亚洲在线观看视频| 国产精品免费视频久久久| 欧美壮男野外gaytube| 97精品免费视频| 欧洲一区二区视频| 欧美有码在线观看| 亚洲第一级黄色片| 精品高清美女精品国产区| www.久久久久久.com| 久久精品久久精品亚洲人| 高清视频欧美一级| 亚洲精品日韩欧美| 日韩国产精品一区| 色哟哟网站入口亚洲精品| 26uuu另类亚洲欧美日本老年| 欧美激情视频在线| 国产午夜精品免费一区二区三区| 国产精品男人爽免费视频1| 视频在线一区二区| 国产精品爽爽爽爽爽爽在线观看| 国产精品一香蕉国产线看观看| 欧美视频在线观看 亚洲欧| 亚洲午夜久久久久久久| 亚洲欧美激情在线视频| 尤物九九久久国产精品的分类| 亚洲美女自拍视频| 国产一区二区三区视频在线观看| 九九久久久久久久久激情| 亚洲国产小视频在线观看| 欧美精品videossex性护士| 18一19gay欧美视频网站| 1769国产精品| 国产成人在线播放| 欧美肥臀大乳一区二区免费视频| 国产亚洲aⅴaaaaaa毛片| 精品视频偷偷看在线观看| 日韩精品在线观看一区| 国产69精品久久久| 精品日韩视频在线观看| 不卡av电影在线观看| 日韩一区二区在线视频| 亚洲人成网站免费播放| 亚洲成人免费在线视频| 欧美午夜丰满在线18影院| 国产精品白丝jk喷水视频一区| 中文字幕av一区二区三区谷原希美| 亚洲色图第三页| 成人妇女免费播放久久久| 尤物yw午夜国产精品视频| 茄子视频成人在线| 国产精品日日做人人爱| 高清欧美一区二区三区| 成人日韩av在线| 国产性色av一区二区| 色婷婷av一区二区三区久久| 97av在线视频免费播放| 久久青草精品视频免费观看| 亚洲综合一区二区不卡| 91色琪琪电影亚洲精品久久| 亚洲aⅴ日韩av电影在线观看| 亚洲免费成人av电影| 97av在线播放| 午夜美女久久久久爽久久| 亚洲精品永久免费精品| 日韩女优在线播放| 国产精品三级美女白浆呻吟| 欧美丰满少妇xxxxx做受| 中文字幕免费精品一区高清| 国产精品偷伦视频免费观看国产| 日韩精品免费电影| 日韩最新中文字幕电影免费看| 亚洲电影第1页| 按摩亚洲人久久| 国产日韩中文字幕| 亚洲曰本av电影| 久久亚洲精品小早川怜子66| 久久久久这里只有精品| 2024亚洲男人天堂| 久久久久久91香蕉国产| 2020国产精品视频|