這篇文章將為大家詳細(xì)講解有關(guān)C++怎么實現(xiàn)歸并排序算法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)公司基于分布式IDC數(shù)據(jù)中心構(gòu)建的平臺為眾多戶提供德陽機(jī)房托管 四川大帶寬租用 成都機(jī)柜租用 成都服務(wù)器租用。
歸并
歸并排序(MERGE-SORT)是建立在歸并操作上的一種有效的排序算法,該算法是采用分治法(Divide and Conquer)的一個非常典型的應(yīng)用。將已有序的子序列合并,得到完全有序的序列;即先使每個子序列有序,再使子序列段間有序。若將兩個有序表合并成一個有序表,稱為二路歸并。
算法描述
歸并操作的工作原理如下:
1、申請空間,使其大小為兩個已經(jīng)排序序列之和,該空間用來存放合并后的序列
2、設(shè)定兩個指針,最初位置分別為兩個已經(jīng)排序序列的起始位置
3、比較兩個指針?biāo)赶虻脑?,選擇相對小的元素放入到合并空間,并移動指針到下一位置
4、重復(fù)步驟3直到某一指針超出序列尾
5、將另一序列剩下的所有元素直接復(fù)制到合并序列尾
圖示
C++代碼
#includeusing namespace std; //比較相鄰序列 void Merge(int arr[],int temp[],int start,int mid,int end){ int i = start,j = mid + 1,k = start; //將較小值放入申請序列 while(i != mid+1 && j != end+1){ if(arr[i] > arr[j]) temp[k++] = arr[j++]; else temp[k++] = arr[i++]; } //將多余的數(shù)放到序列末尾 while(i != mid+1) temp[k++] = arr[i++]; while(j != end+1) temp[k++] = arr[j++]; //更新序列 for(i = start;i <= end;i++) arr[i] = temp[i]; } void MergeSort(int arr[],int temp[],int start,int end){ int mid; if(start < end){ //避免堆棧溢出 mid = start + (end - start) / 2; //遞歸調(diào)用 MergeSort(arr,temp,start,mid); MergeSort(arr,temp,mid+1,end); Merge(arr,temp,start,mid,end); } } int main(){ int a[8] = {50, 10, 20, 30, 70, 40, 80, 60}; int i, b[8]; MergeSort(a, b, 0, 7); for(i=0; i<8; i++) cout< 關(guān)于“C++怎么實現(xiàn)歸并排序算法”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
網(wǎng)站標(biāo)題:C++怎么實現(xiàn)歸并排序算法
文章來源:http://weahome.cn/article/gjcdpp.html