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

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

C++插入排序算法實例詳解

2020-05-23 13:32:08
字體:
來源:轉載
供稿:網友

本文實例為大家分享了C++插入排序算法實例的具體代碼,供大家參考,具體內容如下

基本思想

每次將一個待排序的元素,按其大小插入到已經排好序的子序列的適當位置,知道全部元素插入完成為止。

直接插入排序

1.排序思路

arr[0...i-1]為有序區(剛開始時i=1,有序區只有arr[0]一個元素),arr[i...size]為待排序區,每次將待排序區的第一個元素arr[i]插入到有序區中的適當位置,每趟操作都使有序區增加一個元素,待排序區減少一個元素。

2.排序算法

void InsertSort(int* arr, int size) {   if (arr == NULL)     return;    for (int i = 1; i < size; i++)   {     //1.保存要排序的數     int tmp = arr[i];       //2.去有序區尋找該數應該插入的位置     int j = i - 1;     while (j >= 0 && tmp < arr[j])     {       //3.把有序區的位置一個一個往后移       arr[j + 1] = arr[j];       j--;     }     arr[j + 1] = tmp;   } } 

3.算法分析

直接插入排序由兩重循環構成,外循環進行n-1次。
若初始數據序列遞增有序即為正序時,每一趟排序不進入內循環,僅進行一次大小比較。此時元素移動次數為2次(tmp = arr[i]和arr[j+1] = tmp)。所以正序時比較次數和元素移動次數均達到最小值Cmin和Mmin:

Cmin = n-1
Mmin = 2(n-1)

若初始數據序列遞減有序即為逆序時,因當前有序區的元素均大于待排序區的元素,所以需要將待插入元素與arr[0...i-1]中全部元素進行比較,這需要進行i次比較;內循環中需將arr[0...i-1]中所有元素后移(i-1)-0+1 = i次,外加tmp = arr[i]和arr[j+1] = tmp的兩次移動,一趟排序所需的元素移動次數為i+2次。所以逆序時比較次數和元素移動次數均達到最da值Cmax和Mmax:

Cmax = n(n-1) / 2
Mmax = (n-1)(n+4) / 2

正序時直接插入排序算法的時間復雜度為O(N),逆序時直接插入排序算法的時間復雜度為O(N^2)。
故直接插入排序算法的時間復雜度為O(N^2)。由于只使用了i、j、tmp三個輔助變量,故空間復雜度為O(1)。
當i > j且arr[i] = arr[j]時,直接將arr[i]插入到arr[j]后,故直接插入排序是穩定的。

折半插入排序(二分插入排序)

1.排序思路

采用折半查找方法先在arr[0...i-1]中找到插入位置,再通過移動元素進行插入
2.排序算法

void InsertSort1(int* arr, int size) {   if (arr == NULL)     return;    int i, j, low, high;   //1.保存要插入的數   for (i = 1; i < size; i++)   {     int tmp = arr[i];     low = 0;     high = i - 1;     //2.折半查找插入位置(插入位置為high+1)     while (low <= high)     {       int mid = low + ((high - low) >> 1);       if (tmp < arr[mid])         high = mid - 1;       else         low = mid + 1;     }     //3.元素后移,插入     for (j = i - 1; j >= high + 1; j--)     {       arr[j + 1] = arr[j];     }     arr[j + 1] = tmp;   }   } 

3.算法分析

當初始數據序列為正序時,比較次數并不能減少;當為逆序時,比較次數也不會增加。元素移動次數與直接插入排序相同。
故折半插入排序的時間復雜度為O(N^2),空間復雜度為O(1),是穩定的。
就平均性能而言,折半查找優于順序查找,所以折半插入排序優于直接插入排序。

希爾排序

1.排序思路

希爾排序是一種分組插入排序。先取一個小于n的整數d1,作為第一個增量,序列被分為d1組,所有相互之間距離為d1的倍數的元素放在同一個組中,在各組內進行直接插入排序;然后取第二個增量d2(<d1),重復上述過程,直至增量為1。
希爾排序每趟并不產生有序區,在最后一趟排序結束之前,所有元素并不一定歸位,每趟排完之后,數據越來越接近有序。

2.排序算法

void ShellSort(int* arr, int size) {   if (arr == NULL)     return;    int i, j, gap;   //1.取gap   gap = size / 2;   while (gap > 0)   {     //2.分組比較     for (i = gap; i < size; i++)     {       int tmp = arr[i];       //3.移動元素,插入       j = i - gap;       while (j >= 0 && tmp < arr[j])       {         arr[j + gap] = arr[j];         j -= gap;       }       arr[j + gap] = tmp;     }     gap = gap / 2;   } } 

3.算法分析

希爾排序算法的性能分析是一個復雜的問題,它的時間復雜度與所取gap有關,一般認為其時間復雜度為O(N^1.3),空間復雜度為O(1)。
希爾排序是一種不穩定的算法。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久中文字幕在线视频| 亚洲精品久久久一区二区三区| 国产精品夜色7777狼人| 国产精品盗摄久久久| 亚洲精品美女免费| 久久久综合免费视频| 国产精品一区二区三区毛片淫片| 日本中文字幕不卡免费| 国产精品一二三视频| 91国语精品自产拍在线观看性色| 亲爱的老师9免费观看全集电视剧| 国产精品电影网站| 亚洲第一综合天堂另类专| 国产精品久久久久久久久久尿| 欧美特级www| 欧美成人手机在线| 精品亚洲一区二区三区在线播放| 精品久久久久久久久久ntr影视| 欧美人与性动交| 精品中文视频在线| 日韩一区二区三区xxxx| 69影院欧美专区视频| 日韩男女性生活视频| 国产精品免费电影| 精品电影在线观看| 国产91精品不卡视频| 国产精品专区第二| 亚洲一区二区日本| 久久成人精品一区二区三区| 久久视频免费在线播放| 国产日韩欧美在线视频观看| 性日韩欧美在线视频| 亚洲精品免费av| 免费不卡欧美自拍视频| 亚洲午夜国产成人av电影男同| 亚洲护士老师的毛茸茸最新章节| 在线观看日韩www视频免费| 久久九九国产精品怡红院| 亚洲电影免费观看高清完整版在线| 亚洲国内精品在线| 欧美午夜激情视频| 川上优av一区二区线观看| 一区二区三区天堂av| 亚洲激情国产精品| 国产精品美女999| 国产69精品久久久久久| 国产98色在线| 亚洲黄色在线看| 成人在线一区二区| 欧美激情xxxx性bbbb| 国产综合久久久久久| 国产精品电影网| 日韩高清有码在线| 久久久精品999| 成人免费黄色网| 麻豆一区二区在线观看| 欧美高清视频在线| 欧美放荡办公室videos4k| 精品国产区一区二区三区在线观看| 亚洲天堂网在线观看| 综合激情国产一区| 欧美孕妇性xx| 色无极亚洲影院| 亚洲成人aaa| 国产亚洲成精品久久| 亚洲国产中文字幕在线观看| 国产69精品99久久久久久宅男| 免费97视频在线精品国自产拍| 尤物99国产成人精品视频| 91色在线观看| 国产精品第8页| 日韩美女视频免费在线观看| 日韩电影免费观看中文字幕| 伊人久久综合97精品| 92福利视频午夜1000合集在线观看| 亚洲精品v天堂中文字幕| 夜夜嗨av一区二区三区免费区| 成人午夜激情网| 55夜色66夜色国产精品视频| 国产在线观看一区二区三区| 69精品小视频| 91亚洲人电影| 色香阁99久久精品久久久| 97久久精品人搡人人玩| 欧美激情一二三| 国产成人一区二区| 日韩精品中文字幕视频在线| 国产精品色午夜在线观看| 亚洲性av在线| 国产在线视频91| 亚洲天堂av电影| 韩剧1988在线观看免费完整版| 草民午夜欧美限制a级福利片| 久久久久久久999| 亚洲免费福利视频| 精品久久久av| 国产精品旅馆在线| 91久热免费在线视频| 精品欧美激情精品一区| 久青草国产97香蕉在线视频| 亚洲激情在线视频| 亚洲第一黄色网| 亚洲精品456在线播放狼人| 日本成熟性欧美| 韩国视频理论视频久久| 日韩视频―中文字幕| 国内精品模特av私拍在线观看| 精品国产91久久久久久老师| 欧美激情精品久久久久久久变态| 日韩av免费网站| 国产精品69久久久久| 97精品国产aⅴ7777| 国产精品视频1区| 91视频免费在线| 亚洲国产精品人人爽夜夜爽| 国产精品高潮视频| 亚洲品质视频自拍网| 久久久免费av| 日韩中文字在线| 国产精品96久久久久久又黄又硬| 日韩国产高清污视频在线观看| 日韩在线观看免费高清完整版| 亚洲精品黄网在线观看| 91精品国产乱码久久久久久久久| 黄色成人在线免费| 国产精品视频自在线| 亚洲精品久久久久久久久| 欧美精品免费播放| 国产精品a久久久久久| 国产亚洲激情在线| 国产日韩欧美在线视频观看| 中文字幕欧美日韩精品| 亚洲a区在线视频| 91精品视频专区| 最近2019年中文视频免费在线观看| 欧美性xxxxx极品娇小| 欧洲亚洲免费视频| 日韩欧美中文在线| 亚洲精品中文字幕av| 国内精品美女av在线播放| 在线观看国产精品日韩av| 国产精品入口福利| 日本一区二区不卡| 国产精品久久久久久av福利| 最新69国产成人精品视频免费| 国产精品久久久久999| 一本一本久久a久久精品综合小说| 日韩精品在线私人| 国产99久久精品一区二区| 日韩精品免费一线在线观看| 久久久久久久香蕉网| 国产女人精品视频| 亚洲福利视频网站| …久久精品99久久香蕉国产| 亚洲人成免费电影| 精品国产依人香蕉在线精品| 欧美性生交xxxxxdddd| 午夜精品久久久99热福利| 久久久久久久av| 欧美性在线观看| 欧美在线视频网| 国内偷自视频区视频综合| www.国产一区| 日韩av电影手机在线观看|