久久亚洲精品成人_国产精品欧美综合亚洲_亚洲va天堂va欧美ⅴa在线_91色视频在线观看_久久影院亚洲_一级黄色片播放_日韩av在线一区_精品一区二区在线看_老头吃奶性行交视频_日韩免费高清视频_天天操天天爽天天干_日本欧美在线视频

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

基于C++實現的各種內部排序算法匯總

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

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

C++實現代碼如下:

/************************************************************************* > File Name: sort.cpp > Author: SongLee ************************************************************************/#include<iostream>using namespace std;typedef int ElementType;/* *<<直接插入排序>> * 為了實現N個數的排序,將后面N-1個數依次插入到前面已排好的子序列中, *假定剛開始第1個數是一個已排好序的子序列。經過N-1趟就能得到一個有序序列。 *****時間復雜度:最好情況O(n),最壞情況O(n^2),平均情況O(n^2). *****空間復雜度:O(1) *****穩定性:穩定 */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; }}/* *<<折半插入排序>> * 與直接插入排序不同的是,折半插入排序不是邊比較邊移動,而是將比較和移 *動操作分離出來,即先折半查找出元素的待插入位置,然后再統一地移動待插入位 *置之后的所有元素。不難看出折半插入排序僅僅是減少了比較的次數。 *****時間復雜度:O(n^2) *****空間復雜度:O(1) *****穩定性:穩定 */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) // 統一后移 A[j+1] = A[j]; A[high+1] = temp; // 插入 }}/* *<<希爾排序>> * 希爾排序通過比較相距一定間隔的元素,即形如L[i,i+d,i+2d,...i+kd]的序列 *然后縮小間距,再對各分組序列進行排序。直到只比較相鄰元素的最后一趟排序為 *止,即最后的間距為1。希爾排序有時也叫做*縮小增量排序* *****時間復雜度:依賴于增量序列的選擇,但最壞情況才為O(N^2) *****空間復雜度:O(1) *****穩定性:不穩定 */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) *****穩定性:穩定 */void BubbleSort(ElementType A[], int n){ for(int i=0; i<n-1; ++i) { bool flag = false; // 表示本次冒泡是否發生交換的標志 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) *****穩定性:不穩定 */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) *****穩定性:不穩定 */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]看成是一棵完全二叉 *樹的順序存儲結構,利用完全二叉樹中雙親節點和孩子節點之間的內在關系,在當 *前無序區中選擇關鍵字最大(或最小)的元素。堆排序的思路是:首先將序列L[n] *的n個元素建成初始堆,由于堆本身的特點(以大根堆為例),堆頂元素就是最大 *值。輸出堆頂元素后,通常將堆底元素送入堆頂,此時根結點已不滿足大根堆的性 *質,堆被破壞,將堆頂元素向下調整使其繼續保持大根堆的性質,再輸出堆頂元素。 *如此重復,直到堆中僅剩下一個元素為止。 *****時間復雜度:O(nlogn) *****空間復雜度:O(1) *****穩定性:不穩定 */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) *****穩定性:穩定 */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;}

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
日日夜夜精品网站| 久久免费黄色| 国产综合免费视频| 久久涩涩网站| 97人人爽人人喊人人模波多| 亚洲成人教育av| 亚洲成av人片www| 91视视频在线观看入口直接观看www | 日本一区二区不卡在线| 涩多多在线观看| 91免费版看片| 欧美一区二区视频在线| 亚洲www在线观看| 日日骚av一区| 精品无人区乱码1区2区3区在线| 亚洲成av人片| 亚洲欧洲日韩女同| 成人激情动漫在线观看| 天天色综合久久| 国产一区免费看| 久久黄色免费视频| 欧美性生交大片| 深田咏美中文字幕| 性欧美1819| 日韩a∨精品日韩在线观看| 久久婷婷人人澡人人喊人人爽| 国产精品免费视频xxxx| 欧美放荡办公室videos4k| 亚洲性av网站| 欧美精品一区男女天堂| 欧美精品精品一区| 亚洲成人资源网| **欧美大码日韩| 中文字幕av一区二区三区高 | 97免费在线视频| 综合久久五月天| 色94色欧美sute亚洲线路二| 亚洲成a人片在线观看中文| 中文字幕在线一区免费| 国产精品乱码一区二三区小蝌蚪| 五月婷婷六月丁香综合| 精品人妻一区二区三区浪潮在线| 午夜精品一区二| 性无码专区无码| 性无码专区无码| 在线免费观看av网址| 亚洲欧美另类在线视频| 日韩女同强女同hd| 五月婷婷激情视频| 黄色大全在线观看| 国产偷人妻精品一区二区在线| 中文字幕欧美人妻精品一区蜜臀| 中文字幕 日韩有码| 日日骚一区二区三区| 蜜桃视频最新网址| 免费无码毛片一区二区app| 久久久久久久久久久久久久免费看| 一级黄色免费视频| 在线xxxxx| 久操视频免费看| 久久久久久久久毛片| 人妻少妇一区二区| 日韩视频中文字幕在线观看| 久久香蕉精品视频| 免费看av在线| 一级做a爰片久久毛片16| www.我爱av| 日本不卡高清视频| 91在线国产观看| 亚洲欧美另类在线| 欧美这里有精品| 亚洲高清久久久久久| 日韩一区二区欧美| 国产成人精品亚洲精品| 国产91精品入口17c| 亚洲精品日韩成人| 99视频精品免费| 性欧美18—19sex性高清| 香蕉久久久久久久| 四虎影院在线免费播放| 久久综合亚州| 97精品国产露脸对白| 亚洲国产精品久久久久婷婷884 | 超碰在线公开97| 久久久高清视频| 亚洲av综合一区二区| 成人免费毛片东京热| 做爰无遮挡三级| 精品一区二区三区久久久| 国产精品久久看| 欧美丝袜丝nylons| 日韩三级影视基地| 91精品天堂| 999一区二区三区| 污污免费在线观看| 免费看毛片网站| 日韩电影在线观看一区| 久久久久9999亚洲精品| 欧美色综合网站| 欧美激情网站在线观看| 欧美亚洲在线播放| 欧美亚洲另类在线一区二区三区| 男人添女人下部视频免费| 国产成人综合一区| 成人黄色短视频| 亚洲av色香蕉一区二区三区| 久久久久久久一区| 欧美一区二区三区在线看| 欧美激情喷水视频| 一区二区免费电影| www日本在线观看| 奴色虐av一区二区三区| 国产原创一区二区三区| 精品毛片网大全| 欧美国产乱视频| 亚洲高清精品中出| 精品影片一区二区入口| 久久久精品视频免费观看| 天天操天天干天天舔| 中文字幕av资源一区| 亚洲国产日韩欧美在线99| 91久久精品美女高潮| 欧美一级片中文字幕| 国产乡下妇女做爰视频| 国产成人自拍高清视频在线免费播放| 日韩欧美精品网站| 69精品小视频| 亚洲一区三区在线观看| 天天躁日日躁aaaa视频| 日韩精品亚洲一区二区三区免费| 国产99精品在线观看| 亚洲人成网在线播放| 欧美自拍第一页| 熟女少妇a性色生活片毛片| 激情五月五月婷婷| 日韩视频―中文字幕| 精品国产99国产精品| 国产精品欧美一区喷水| 亚洲男人天堂久| 国产精品香蕉av| 亚洲天堂网一区| 中文字幕人妻一区二区在线视频 | 99精品偷自拍| 精品日韩一区二区| 精品一区二区三区视频日产| 色悠悠在线视频| 日本黄色免费视频| 欧美性xxxx| 97在线免费观看视频| aⅴ在线免费观看| 在线观看你懂的网站| 亚洲色图欧美偷拍| 中文字幕在线看视频国产欧美| 视频一区视频二区视频三区视频四区国产| www.久久国产| 国产+成+人+亚洲欧洲自线| 精品国产91洋老外米糕| 91丝袜美腿美女视频网站| 久久久久xxxx| 免费在线观看日韩欧美| 欧美午夜影院在线视频| 国产精品一区二区三区在线播放| 野战少妇38p| 国产精品一级在线| 亚洲色图在线观看| 国产91xxx| 国产女人18毛片水真多| 欧美特黄级在线| 国产一区二区三区奇米久涩| 999精品视频在线观看播放| 2020国产精品自拍| 中文字幕成人在线| 日韩毛片在线免费看| 亚洲免费视频网| 91精品国产色综合久久| 7777在线视频| 高潮毛片7777777毛片| 色婷婷综合五月| 精品欧美国产| 久久黄色精品视频| 一本大道av一区二区在线播放| 91九色蝌蚪嫩草| 免费麻豆国产一区二区三区四区| 国产精品乱码人人做人人爱| 2019亚洲男人天堂| 美女被到爽高潮视频| 国产喷白浆一区二区三区| 538国产精品一区二区免费视频| 一级黄色片在线免费观看| 成人sese在线| 国产成人综合精品| 青青操国产视频| 欧美日韩午夜剧场| 五月天在线免费视频| 午夜老司机福利| 欧美久久久久久久久久| 国产精品波多野结衣| 国产成人手机在线| 中文字幕日韩av电影| av影片在线播放| 欧美极品aⅴ影院| 91在线免费看片| 手机在线免费看毛片| 精品久久久在线观看| 亚洲高清资源综合久久精品| 精品国产99久久久久久宅男i| 亚洲精品黄网在线观看| 欧美性猛交xxxx乱大交91| 久久香蕉国产线看观看99| 国产精品视频导航| 在线观看毛片av| 成人小视频免费观看| 国产精品久久久久久婷婷天堂| 欧美色图一区二区| 欧美不卡视频一区| 四季av综合网站| 色婷婷综合久久| 欧美三级午夜理伦三级富婆| 国产精品久久99| 久久久久福利视频| 成人在线视频首页| 日韩福利影院| 风间由美性色一区二区三区 | 日韩一区二区在线看| 午夜精品免费看| 亚洲丰满少妇videoshd| 无码少妇一区二区三区芒果| 青草国产精品久久久久久| 91精品国产91久久| 亚洲一级在线播放| 国产69久久精品成人| 在线播放成人av| 91高潮在线观看| 中文字幕人妻一区二区三区视频| 欧美大荫蒂xxx| 欧美性猛交xxxx乱大交hd| 久久久久久久久艹| 日韩av在线播放资源| 亚洲精品国产精品国自| 日韩成人av网址| 黑人巨大精品一区二区在线| 正在播放亚洲1区| 久草手机在线视频| 色综合视频网站| 精品国产av一区二区三区| 国产美女扒开尿口久久久| 午夜av免费观看| 国产高清一区二区三区| 国产精品一区二区久久精品爱涩| 在线观看成人一级片| 亚洲日穴在线视频| 免费av不卡在线| 日韩亚洲欧美中文三级| 侵犯稚嫩小箩莉h文系列小说| 色av中文字幕一区| 中文字幕有码视频| 亚洲精品女av网站| 成人高清视频免费观看| 免费看国产一级片| 欧美午夜视频网站| 538精品在线视频| 国模私拍一区二区三区| 日韩在线观看视频一区二区三区| 久久精品国产一区二区三区不卡| 久久蜜桃av一区精品变态类天堂 | 日本一区二区三区在线观看| aⅴ在线免费观看| 在线一区二区视频| 欧美一级片在线视频| 欧美精品久久久久a| 五月婷婷在线观看视频| 先锋影音男人资源| 精品久久久久久久久久久久久久 | 欧美国产视频一区| 黄色一区二区在线观看| 日韩精品电影一区二区三区| 精品中文字幕在线观看| 日韩成人一区二区| 国产91视频一区| 欧美美女bb生活片| 综合网在线观看| 国产高清一区视频| 国产精品久久毛片| 一区二区三区在线观看免费视频| 国产69精品久久久久9999| 国产一区在线观看麻豆| 六月丁香婷婷在线| 亚洲国产精品久久久久秋霞蜜臀 | 正在播放国产精品| 91成人在线免费观看| 国产对白videos麻豆高潮| 国产精品色午夜在线观看| 99久久精品国产毛片| 免费观看黄网站| 欧美日韩xxx| 成人免费毛片片v| 丰满熟女人妻一区二区三区| 欧美精品在线第一页| 国产在线视频一区二区三区| 性chinese极品按摩| 蜜月aⅴ免费一区二区三区| 精品一二线国产| 五月六月丁香婷婷| 国产亚洲综合视频| 欧美性猛交xxxx乱大交蜜桃| 欧美日韩精品亚洲精品| 91色琪琪电影亚洲精品久久| 国产精品视频看| 黄色国产在线播放| 奇米成人av国产一区二区三区| 成人精品小蝌蚪| 国产精品九九九九九| 日韩av黄色在线观看| 欧美高清在线一区| 天天看片中文字幕| 精品国产综合久久| 欧美精品视频www在线观看| www.久久综合| 91淫黄看大片| 亚洲18私人小影院| 亚洲色图在线播放| 天天干,天天干| 国产特级淫片高清视频| 日韩在线观看成人| 久久久综合视频| 黄色一级片在线| 亚洲人一区二区| 亚洲美女av黄| 成人福利视频网站| 午夜激情福利网| 亚洲欧美久久久久一区二区三区| 精品国产乱码久久久久久蜜臀| 日本大胆欧美人术艺术动态| 免费不卡av网站| 国产主播欧美精品| 欧美日韩不卡一区二区| 日av在线不卡| 久久精品国产亚洲av久| 精品一卡二卡三卡四卡日本乱码 | 免费超爽大片黄| 久久影院在线观看| 亚洲图片你懂的| 国产又爽又黄免费软件| 小泽玛利亚视频在线观看| 国产精品成人免费视频| 色天天综合久久久久综合片| 日韩一级片免费观看| 北京富婆泄欲对白| 欧美一区国产一区| 少妇高潮久久77777| 亚洲人妖av一区二区| 国产ts变态重口人妖hd| 午夜免费福利网站| 999视频在线观看| 亚洲国产日韩欧美在线99| 91麻豆文化传媒在线观看| 青青青国产在线| 日韩在线xxx| 成人深夜直播免费观看| 亚洲成人久久一区| 久久久99精品免费观看| 国产又黄又粗又硬| 亚洲少妇18p| 中文字幕久精品免| 97精品一区二区视频在线观看| 日本高清视频一区二区| 国产综合一区二区| 国产网友自拍视频| 亚洲综合欧美在线| 丁香五月网久久综合| 丝袜亚洲欧美日韩综合| 五月天一区二区| 国产精品一二三| 亚洲精品91天天久久人人| 在线中文字日产幕| 一区二区三区四区欧美日韩| 97久久久久久| 亚洲成人久久一区| 一区二区三区四区在线播放| 久久久久久黄| 黄色一级片免费看| 少妇熟女视频一区二区三区| 亚洲国产一区二区在线| 国产成人精品a视频一区www| 精品香蕉一区二区三区| 亚洲一区二区三区四区五区黄 | 婷婷免费在线观看| 少妇精品久久久久久久久久| 国产成人精品免费久久久久| 亚洲乱码av中文一区二区| 亚洲成人高清在线| 成人av免费在线播放| 亚洲精品久久久蜜桃动漫| 极品色av影院| 99日在线视频| 97久久国产亚洲精品超碰热| 成人免费视频观看视频| 992tv成人免费视频| 亚洲精品中文字| 欧美性大战xxxxx久久久| 国产精品乱码一区二三区小蝌蚪| 久久99精品一区二区三区三区| www.av88| 国产盗摄一区二区三区在线| 国模无码视频一区| 日韩av片网站| 久久久99精品视频| 亚洲精品一区二区三区av| 国内精品久久久久久久果冻传媒| 国产精品久久久久久搜索 |