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

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

基于C++實現(xiàn)的各種內部排序算法匯總

2020-05-23 14:22:12
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了基于C++實現(xiàn)的各種內部排序算法,非常經典,需要的朋友可以參考下
 
 

提起排序算法相信大家都不陌生,或許很多人已經把它們記得滾瓜爛熟,甚至隨時可以寫出來。是的,這些都是最基本的算法。這里就把各種內部排序算法總結歸納了一下,包括插入排序(直接插入排序,折半插入排序,希爾排序)、交換排序(冒泡排序,快速排序)、選擇排序(簡單選擇排序,堆排序)、2-路歸并排序。(另:至于堆排序算法,前面已經有一篇文章針對堆排序的算法實現(xiàn)做了詳細的描述)

C++實現(xiàn)代碼如下:

/************************************************************************* > File Name: sort.cpp > Author: SongLee ************************************************************************/#include<iostream>using namespace std;typedef int ElementType;/* *<<直接插入排序>> * 為了實現(xiàn)N個數的排序,將后面N-1個數依次插入到前面已排好的子序列中, *假定剛開始第1個數是一個已排好序的子序列。經過N-1趟就能得到一個有序序列。 *****時間復雜度:最好情況O(n),最壞情況O(n^2),平均情況O(n^2). *****空間復雜度:O(1) *****穩(wěn)定性:穩(wěn)定 */void InsertSort(ElementType A[], int n){ int i,j; ElementType temp; // 臨時變量 for(i=1; i<n; ++i) { temp = A[i];  for(j = i; j>0 && A[j-1]>temp; --j) A[j] = A[j-1]; A[j] = temp; }}/* *<<折半插入排序>> * 與直接插入排序不同的是,折半插入排序不是邊比較邊移動,而是將比較和移 *動操作分離出來,即先折半查找出元素的待插入位置,然后再統(tǒng)一地移動待插入位 *置之后的所有元素。不難看出折半插入排序僅僅是減少了比較的次數。 *****時間復雜度:O(n^2) *****空間復雜度:O(1) *****穩(wěn)定性:穩(wěn)定 */void BinaryInsertSort(ElementType A[], int n){ int i, j, low, high, mid; ElementType temp; for(i=1; i<n; ++i) { temp = A[i]; low = 0; high = i-1; // 設置折半查找的范圍 while(low <= high) { mid = (low+high)/2; // 取中間點 if(A[mid] > temp) high = mid-1; else low = mid+1; } for(j=i-1; j>=high+1; --j) // 統(tǒng)一后移 A[j+1] = A[j]; A[high+1] = temp; // 插入 }}/* *<<希爾排序>> * 希爾排序通過比較相距一定間隔的元素,即形如L[i,i+d,i+2d,...i+kd]的序列 *然后縮小間距,再對各分組序列進行排序。直到只比較相鄰元素的最后一趟排序為 *止,即最后的間距為1。希爾排序有時也叫做*縮小增量排序* *****時間復雜度:依賴于增量序列的選擇,但最壞情況才為O(N^2) *****空間復雜度:O(1) *****穩(wěn)定性:不穩(wěn)定 */void ShellSort(ElementType A[], int n){ int i, j, dk; // dk是增量 ElementType temp;  for(dk=n/2; dk>0; dk/=2) // 增量變化 { for(i=dk; i<n; ++i) // 每個分組序列進行直接插入排序 { temp = A[i]; for(j=i-dk; j>=0 && A[j]>temp; j-=dk) A[j+dk] = A[j]; // 后移 A[j+dk] = temp; } }}/* *<<冒泡排序>> * 冒泡排序的基本思想是從后往前(或從前往后)兩兩比較相鄰元素的值,若為 *逆序,則交換它們,直到序列比較完。我們稱它為一趟冒泡。每一趟冒泡都會將一 *個元素放置到其最終位置上。 *****時間復雜度:最好情況O(n),最壞情況O(n^2),平均情況O(n^2) *****空間復雜度:O(1) *****穩(wěn)定性:穩(wěn)定 */void BubbleSort(ElementType A[], int n){ for(int i=0; i<n-1; ++i) { bool flag = false; // 表示本次冒泡是否發(fā)生交換的標志 for(int j=n-1; j>i; --j) // 從后往前 { if(A[j-1] > A[j])  { flag = true; // 交換 A[j-1] = A[j-1]^A[j]; A[j] = A[j-1]^A[j]; A[j-1] = A[j-1]^A[j]; } } if(flag == false) return; }}/* *<<快速排序>> * 快速排序是對冒泡排序的一種改進。其基本思想是基于分治法:在待排序表L[n] *中任取一個元素pivot作為基準,通過一趟排序將序列劃分為兩部分L[1...K-1]和 *L[k+1...n],是的L[1...k-1]中的所有元素都小于pivot,而L[k+1...n]中所有元素 *都大于或等于pivot。則pivot放在了其最終位置L(k)上。然后,分別遞歸地對兩個子 *序列重復上述過程,直至每部分內只有一個元素或空為止,即所有元素放在了其最終 *位置上。 *****時間復雜度:快排的運行時間與劃分是否對稱有關,最壞情況O(n^2),最好情況 *O(nlogn),平均情況為O(nlogn) *****空間復雜度:由于需要遞歸工作棧,最壞情況為O(n),平均情況為O(logn) *****穩(wěn)定性:不穩(wěn)定 */int Partition(ElementType A[], int low, int high){ // 劃分操作有很多版本,這里就總以當前表中第一個元素作為樞紐/基準 ElementType pivot = A[low]; while(low < high) { while(low<high && A[high]>=pivot) --high; A[low] = A[high]; // 將比樞紐值小的元素移到左端 while(low<high && A[low]<=pivot) ++low; A[high] = A[low]; // 將比樞紐值大的元素移到右端 } A[low] = pivot; // 樞紐元素放到最終位置 return low;  // 返回樞紐元素的位置}void QuickSort(ElementType A[], int low, int high){ if(low < high) // 遞歸跳出的條件 { int pivotPos = Partition(A, low, high); // 劃分操作,返回基準元素的最終位置 QuickSort(A, low, pivotPos-1); // 遞歸 QuickSort(A, pivotPos+1, high); }}/* *<<簡單選擇排序>> * 選擇排序的算法思想很簡單,假設序列為L[n],第i趟排序即從L[i...n]中選擇 *關鍵字最小的元素與L(i)交換,每一趟排序可以確定一個元素的最終位置。經過n-1 *趟排序就可以使得序列有序了。 *****時間復雜度:始終是O(n^2) *****空間復雜度:O(1) *****穩(wěn)定性:不穩(wěn)定 */void SelectedSort(ElementType A[], int n){ for(int i=0; i<n-1; ++i) // 一共進行n-1趟 { int minPos = i; // 記錄最小元素的位置 for(int j=i+1; j<n; ++j) if(A[j] < A[minPos]) minPos = j; if(minPos != i) // 與第i個位置交換 { A[i] = A[i]^A[minPos]; A[minPos] = A[i]^A[minPos]; A[i] = A[i]^A[minPos]; } }}/* *<<堆排序>> * 堆排序是一種樹形選擇排序方法,在排序過程中,將L[n]看成是一棵完全二叉 *樹的順序存儲結構,利用完全二叉樹中雙親節(jié)點和孩子節(jié)點之間的內在關系,在當 *前無序區(qū)中選擇關鍵字最大(或最?。┑脑亍6雅判虻乃悸肥牵菏紫葘⑿蛄蠰[n] *的n個元素建成初始堆,由于堆本身的特點(以大根堆為例),堆頂元素就是最大 *值。輸出堆頂元素后,通常將堆底元素送入堆頂,此時根結點已不滿足大根堆的性 *質,堆被破壞,將堆頂元素向下調整使其繼續(xù)保持大根堆的性質,再輸出堆頂元素。 *如此重復,直到堆中僅剩下一個元素為止。 *****時間復雜度:O(nlogn) *****空間復雜度:O(1) *****穩(wěn)定性:不穩(wěn)定 */void AdjustDown(ElementType A[], int i, int len){ ElementType temp = A[i]; // 暫存A[i]  for(int largest=2*i+1; largest<len; largest=2*largest+1) { if(largest!=len-1 && A[largest+1]>A[largest]) ++largest;   // 如果右子結點大 if(temp < A[largest]) { A[i] = A[largest]; i = largest;   // 記錄交換后的位置 } else break; } A[i] = temp; // 被篩選結點的值放入最終位置}void BuildMaxHeap(ElementType A[], int len){ for(int i=len/2-1; i>=0; --i) // 從i=[n/2]~1,反復調整堆 AdjustDown(A, i, len);}void HeapSort(ElementType A[], int n){ BuildMaxHeap(A, n);  // 初始建堆 for(int i=n-1; i>0; --i) // n-1趟的交換和建堆過程  { // 輸出最大的堆頂元素(和堆底元素交換) A[0] = A[0]^A[i]; A[i] = A[0]^A[i]; A[0] = A[0]^A[i]; // 調整,把剩余的n-1個元素整理成堆 AdjustDown(A, 0, i);  }}/* *<<2-路歸并排序>> * 顧名思義,2-路歸并就是將2個有序表組合成一個新的有序表。假定待排序表 *有n個元素,則可以看成是n個有序的子表,每個子表長度為1,然后兩兩歸并...不 *停重復,直到合成一個長度為n的有序序列為止。Merge()函數是將前后相鄰的兩個 *有序表歸并為一個有序表,設A[low...mid]和A[mid+1...high]存放在同一順序表的 *相鄰位置上,先將它們復制到輔助數組B中。每次從對應B中的兩個段取出一個元素 *進行比較,將較小者放入A中。 *****時間復雜度:每一趟歸并為O(n),共log2n趟,所以時間為O(nlog2n) *****空間復雜度:O(n) *****穩(wěn)定性:穩(wěn)定 */ElementType *B = new ElementType[13]; // 和數組A一樣大void Merge(ElementType A[], int low, int mid, int high){ int i, j, k; for(k=low; k<=high; ++k) B[k] = A[k];    // 將A中所有元素復制到B for(i=low,j=mid+1,k=i; i<=mid&&j<=high; ++k) { if(B[i] <= B[j])  // 比較B的左右兩段序列中的元素 A[k] = B[i++]; // 將較小值復制到A中 else A[k] = B[j++]; } while(i<=mid) A[k++] = B[i++]; // 若第一個表未檢測完,復制 while(j<=high) A[k++] = B[j++]; // 若第二個表未檢測完,復制}void MergeSort(ElementType A[], int low, int high){ if(low < high) { int mid = (low + high)/2; MergeSort(A, low, mid);  // 對左側子序列進行遞歸排序 MergeSort(A, mid+1, high); // 對右側子序列進行遞歸排序 Merge(A, low, mid, high);  // 歸并 }}/* * 輸出函數 */void print(ElementType A[], int n){ for(int i=0; i<n; ++i) { cout << A[i] << " "; } cout << endl;}/* * 主函數 */int main(){ ElementType Arr[13] = {5,2,1,8,3,6,4,7,0,9,12,10,11}; //InsertSort(Arr, 13); //BinaryInsertSort(Arr, 13); //ShellSort(Arr, 13); //BubbleSort(Arr, 13); //QuickSort(Arr, 0, 12); //SelectedSort(Arr, 13); //HeapSort(Arr, 13); //MergeSort(Arr, 0, 12); print(Arr, 13); return 0;}

相信本文所述實例代碼對大家復習和鞏固各類排序算法能起到一定的幫助作用。


發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
国产98在线|日韩| 777色狠狠一区二区三区| 亚洲欧洲日本在线| 国产成人鲁色资源国产91色综| 久久在线视频在线| 日韩中文字幕观看| 全免费a级毛片| 免费观看日批视频| 欧美 亚洲 另类 激情 另类| 鲁鲁狠狠狠7777一区二区| 日日夜夜精品| 亚洲精品字幕在线| 亚洲综合伊人久久大杳蕉| 日韩亚洲欧美高清| 亚洲经典在线| 老司机精品视频在线观看6| 成功精品影院| 日本亚洲精品| av2014天堂网| 午夜精品国产更新| 欧美成人黄色小视频| 可以免费观看的黄色网址| 性xxxx欧美老肥妇牲乱| 国内免费久久久久久久久久久| 免费黄网站在线播放| 亚洲一区二区人妻| 中文av一区特黄| 欧美老少配视频| 日韩中文字幕| 国产偷v国产偷v亚洲高清| 色悠悠久久久久| 中文字幕久久一区| 午夜写真片福利电影网| 久久久久久久久99精品大| 国产日本欧美视频| 欧美日本亚洲视频| 精品一区二区男人吃奶| 日韩高清不卡一区二区三区| 欧美少妇性生活视频| 一级毛片免费在线| 国产在线观看91精品一区| 国产在线精品一区二区不卡| 欧美在线观看一区| 久久精品www人人爽人人| 91高清免费视频| 日韩偷拍自拍| av无码久久久久久不卡网站| 三级网站视频在在线播放| 欧洲成人在线视频| 久久精品国产一区二区三区| 懂色av成人一区二区三区| 菠萝蜜视频在线观看一区| 在线观看免费视频高清游戏推荐| 一本一本久久a久久综合精品| 亚洲色婷婷一区二区三区| 激情成人开心网| 最近中文字幕免费mv| 国产揄拍国内精品对白| 久久午夜精品视频| www.se五月| 91成人免费在线| 日韩精品久久理论片| 国产欧美一区二区精品婷婷| 亚洲6080在线| 欧美1234区| 欧美成人一区二区| 黄色网址多少| 亚洲无玛一区| 亚洲精品伦理| 久久av免费观看| 色综合视频一区中文字幕| 三级视频网站在线观看| 日韩欧美一区电影| 日韩a**中文字幕| 欧美精品一区二区蜜桃| 欧美一级淫片aaaaaa| 欧美精品网站| 亚洲第一福利一区| 爱爱爱爱免费视频| 色偷偷9999www| 一色屋色费精品视频在线看| 国产一区在线视频观看| julia一区二区三区中文字幕| 欧美bbbbbbbbbbbb精品| 日韩在线视频在线| 欧美性感美女一区二区| 香蕉成人啪国产精品视频综合网| 国产精品一区二区性色av| 成人高清在线观看| 成人自拍爱视频| 野外性xxxxfreexxxxx欧美| 免费av不卡在线| 久久99深爱久久99精品| 亚洲欧洲国产日韩| 日韩欧美国产成人精品免费| 色婷婷.com| 91成人在线精品| 成人h精品动漫一区二区三区| 日韩午夜视频在线观看| 不卡免费追剧大全电视剧网站| 中文字幕先锋av影音资源网| 亚洲电影视频在线| 成人满18在线观看网站免费| 特级西西人体www高清大胆| av色影在线看免费| 精品人妻一区二区三区浪潮在线| 久久精品在线观看| 久久国产日韩欧美精品| 大伊人狠狠躁夜夜躁av一区| 日本韩国欧美国产| 激情综合在线| 亚洲日本黄色片| 一区二区三区视频| 中文字幕有码在线观看| 国产精品毛片久久久| jizz在亚洲| 91精产国品一二三| 久久久伦理片| 97超级碰碰人国产在线观看| 日韩欧美国产精品| 亚洲自拍另类综合| 日韩午夜在线电影| 黄色a级片免费| 亚洲啊v在线免费视频| 久久久美女视频| 婷婷六月天丁香| 人人澡人人添人人爽一区二区| 免费黄色影片在线| 国产亚洲精品资源在线26u| 成人6969www免费视频| 99精品国产一区二区三区| 成人网免费视频| 在线观看欧美一区二区| 999在线观看免费大全电视剧| 蜜桃精品视频在线| 波多野结依一区| 精品美女在线观看视频在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 91麻豆6部合集magnet| 男人日女人下面视频| 国产卡一卡二在线| 国偷自拍第113页| 国产av无码专区亚洲精品| 久久7799| 欧美日韩一区二区电影| 岛国片在线看| 日韩一区二区三区免费看| 福利视频一区二区| 欧美国产日韩亚洲一区| 国产综合精品在线| 亚洲一区二区在线观| 国产亚洲精品久久久久动| 亚洲国产一区自拍| 天干天干啦夜天干天2019| 日本一区免费观看| 蜜桃视频在线观看免费视频| 日韩亚洲欧美在线观看| 最近中文字幕在线中文高清版| 岛国一区二区三区高清视频| 1234区中文字幕在线观看| 亚洲美女在线观看| 琪琪五月天综合婷婷| 久草在线资源网站| 蜜桃精品一区二区三区| 99精品在线视频观看| 一区在线中文字幕| 欧美极品视频在线观看| 国内国产区免费视频| 国产麻豆剧果冻传媒观看hd高清| 日韩1区2区| 久久九九精品视频| 一区二区三区四区免费观看| 国产欧美日韩激情| 91啦中文在线| 免费在线观看av网址| 日韩av免费| 日韩免费av一区| 亚洲成人免费在线视频| 亚洲精品一区二区三区精华液| 一区二区三区久久精品| 蜜臀av亚洲一区中文字幕| 亚洲日本aⅴ片在线观看香蕉| 毛片免费在线播放| 欧亚一区二区| 免费av网站在线看| 老女人av在线| 影音先锋中文在线观看| 欧美magnet| 婷婷视频在线观看| 黑人巨大精品欧美一区二区| 欧洲毛片在线视频免费观看| 麻豆精品传媒视频| 日韩成人av毛片| 超碰在线免费97| 欧美6一10sex性hd| 国产91在线播放九色快色| 久久亚洲精品小早川怜子66| 久久久久久久久亚洲精品| 尹人成人综合网| 国产免费黄网站| 青青草激情视频| 国产精品国产精品国产专区蜜臀ah| 91精品国产入口在线| 91极品视觉盛宴| 欧美精品一区二区三区视频| 色视频免费版高清在线观看| 日韩精品一区二区三区视频播放| 综合久久婷婷| 亚洲电影成人| jizzjizzjizz中国免费| 久草在线看片| 欧美精品国产精品| 国产精品无码天天爽视频| 99在线观看视频| 亚洲天堂网视频| 午夜精品久久久久99蜜桃最新版| 无遮挡动作视频在线观看免费入口| 不卡福利视频| 三级福利视频| 少妇精品无码一区二区三区| 午夜精品在线观看| 人妻熟女一二三区夜夜爱| 一本一道无码中文字幕精品热| 欧美在线视频一区二区| 激情小说一区| 97婷婷大伊香蕉精品视频| 在线观看三级视频| 男人的天堂影院| 懂色av蜜臀av粉嫩av分享吧| 午夜精品一区二区三区四区| 中国在线观看免费国语版电影| 欧美性猛交久久久乱大交小说| 亚洲综合在线一区二区| 精品免费在线| 麻豆精品国产传媒mv男同| 亚洲色图 校园春色| 亚洲一区二区中文字幕在线观看| 99久久久精品| 香蕉网站在线观看| 国产三区在线播放| 男女羞羞在线观看| 久久久久久一级片| 91视频啊啊啊| 日本福利片在线| 国产高潮视频在线观看| 国产日本一区二区三区| 成人激情视频在线播放| 精品国产91久久久久久| ed2k情侣啪啪91av| 成人乱码一区二区三区av| 国产精品第一视频| 美女精品久久| 制服.丝袜.亚洲.中文.综合| 性欧美videosex高清少妇| 国产一级在线观看www色| 成人短剧在线观看| 一区二区在线中文字幕电影视频| 日韩在线 中文字幕| 最新日韩精品| 天天操天天干视频| 久久精品欧美一区二区三区不卡| 日本欧美精品久久久| 国产日韩精品一区| eeuss中文| 久久一区二区三区超碰国产精品| 久久久久免费看黄a片app| 亚洲永久精品大片| 中文字幕观看av| 五十路亲子中出在线观看| 99精品在线观看| 日韩av片免费观看| 在线不卡a资源高清| 国产成人免费| 激情av网站| 欧美本精品男人aⅴ天堂| 一本免费视频| 日韩一区欧美二区| 啪啪亚洲精品| 国产高潮视频在线观看| 精品国内亚洲在观看18黄| 波多野结衣综合网| 精品视频在线播放免| 黄色网免费观看| 国产视频91在线| 一区二区三区中文字幕精品精品| 小早川怜子影音先锋在线观看| 啪啪av大全导航福利综合导航| 在线免费观看日本一区| 日韩精品一区二区三区视频| 亚洲高清在线观看一区| 欧美日韩精品在线| 亚洲精品ady| 成人午夜激情av| 国产特级嫩嫩嫩bbb| 日本视频在线免费| 亚洲36d大奶网| 国产精品对白交换视频| eeuss影院在线观看第一页| 91色视频在线导航| 国产精品视频免费一区二区三区| 国产日韩欧美一区二区三区四区| 杨幂一区二区三区免费看视频| 中文字幕在线播出| 沈樵精品国产成av片| 国产欧美在线播放| 青青草国产精品| 欧美日韩亚洲三区| 超碰在线中文字幕| 国产精品69页| 美女少妇精品视频| 丰满岳乱妇一区二区三区| 久久久久久9| 99国内精品久久久久久久| 国产精品视频一区二区三区不卡| 国产无遮挡又黄又爽又色| 亚洲欧美国产高清va在线播放| 欧美午夜一区二区三区| 欧美日产一区二区三区在线观看| 国产欧美日韩免费看aⅴ视频| 中文字幕日韩一区| 99热99re6国产在线播放| 麻豆国产精品| 日韩三级成人av网| 欧美 另类 交| 在线免费色视频| 欧美人与动牲交xxxxbbbb| 自己做鸭怎么接单寻找客源| 欧美激情在线一区二区|