C++如何實現歸并排序-創新互聯

這篇文章主要講解了C++如何實現歸并排序,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。

成都創新互聯專注于企業成都全網營銷推廣、網站重做改版、興平網站定制設計、自適應品牌網站建設、H5開發商城網站開發、集團公司官網建設、成都外貿網站制作、高端網站制作、響應式網頁設計等建站業務,價格優惠性價比高,為興平等各大城市提供網站開發制作服務。

一、思路:穩定排序

(1)劃分:一直調用劃分過程,直到子序列為空或只有一個元素為止,共需log2(n);

(2)歸并:將兩個子序列從小到大合并為一個序列

二、實現程序:

// 歸并排序:(二路歸并)
// (1)遞歸分解數組;
// (2)合并有序的序列
#include <iostream>
using namespace std;
 
// 合并兩個有序的序列
template <typename T>
void Merge(T arr[], int start, int mid, int end) {
  int i, j, k, n1, n2;
  
  k=0;
  n1 = mid - start + 1;
  n2 = end - mid;
  T *L = new T[n1], *R = new T[n2];
  
  for(i = 0; i < n1; i++) // 將arr的左部分賦給L
    L[i] = arr[start+i];
  for(j = 0; j < n2; j++) // 將arr的右部分賦給R
    R[j] = arr[mid+j+1];
  i = 0;
  j = 0;
  k= start;
  while(i < n1 && j < n2) { // 合并
    if(L[i] <= R[j]) {
      arr[k] = L[i];
      i++;
    } else {
      arr[k] = R[j];
      j++;
    }
    k++;
  }
  while(i < n1) { // 左部分沒處理完
    arr[k] = L[i];
    k++;
    i++;
  }
  while(j < n2) { // 右部分沒處理完
    arr[k] = R[j];
    k++;
    j++;
  }
  delete []L;
  delete []R;
}
 
// 歸并排序
template <typename T>
void MergeSort(T arr[], int start, int end) {
  int mid;
  
  if(start >= end)
    return;
  
  mid = (start + end) / 2;
  MergeSort(arr, start, mid);
  MergeSort(arr, mid+1, end);
  Merge(arr, start, mid, end);
}
 
// 輸出數組
template <typename T>
void Print(T arr[], int n) {
  int i;
  
  for(i = 0; i < n; i++)
    cout << arr[i] << " ";
  cout << endl;
}
 
int main(int argc, const char * argv[]) {
  int n, i, arr[50];
  
  cout << "請輸入要排序的數的個數:";
  cin >> n;
  srand((int)time(NULL)); // 設置時間為隨機點
  for(i = 0; i < n; i++) // 產生n個隨機數
    arr[i] = rand() % 100;
  cout << "排序前:";
  Print(arr, n);
  MergeSort(arr, 0, n-1); // 調用歸并排序
  cout << "排序后:";
  Print(arr, n);
  return 0;
}

另外有需要云服務器可以了解下創新互聯建站m.kartarina.com,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。

分享名稱:C++如何實現歸并排序-創新互聯
轉載來于:http://m.kartarina.com/article2/dodioc.html

成都網站建設公司_創新互聯,為您提供動態網站、搜索引擎優化、小程序開發品牌網站設計網站改版、網站策劃

廣告

聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯

手機網站建設
主站蜘蛛池模板: 无码国内精品人妻少妇| 亚洲av无码不卡| 无码日韩精品一区二区人妻 | 久久久久亚洲AV无码专区首JN | 亚洲国产精品无码久久青草| 日韩精品无码一区二区三区四区 | 午夜无码视频一区二区三区| 亚洲色无码专区在线观看| 亚洲AV无码国产剧情| 中文无码伦av中文字幕| 东京热av人妻无码| 无码AV片在线观看免费| 中文字幕人妻三级中文无码视频 | 精品人妻中文无码AV在线| 日韩精品无码一本二本三本| 国内精品人妻无码久久久影院导航| 亚洲av无码有乱码在线观看| 青青草无码免费一二三区| 野花在线无码视频在线播放| 影院无码人妻精品一区二区| 亚洲av成本人无码网站| 无码丰满熟妇juliaann与黑人| 亚洲精品无码专区久久久 | 玖玖资源站无码专区| 亚洲AV永久无码精品一百度影院| 久久久久久av无码免费看大片| 小12箩利洗澡无码视频网站| 无码丰满熟妇浪潮一区二区AV| 无码人妻丝袜在线视频| 亚洲av无码久久忘忧草| 久久久久亚洲AV无码专区首JN| 久久久无码人妻精品无码| 亚洲AV无码乱码国产麻豆| 人妻少妇AV无码一区二区| 国产成人无码精品一区在线观看 | 亚洲国产成人精品无码一区二区| 亚洲爆乳无码一区二区三区| 亚洲AV无码第一区二区三区 | 亚洲一区二区三区AV无码 | 无码国产精品一区二区免费I6| 中文字幕无码成人免费视频|