国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

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

C++歸并排序算法實例

2020-01-26 15:15:53
字體:
來源:轉載
供稿:網友

歸并排序

歸并排序算法是采用分治法的一個非常典型的應用。歸并排序的思想是將一個數組中的數都分成單個的;對于單獨的一個數,它肯定是有序的,然后,我們將這些有序的單個數在合并起來,組成一個有序的數列。這就是歸并排序的思想。它的時間復雜度為O(N*logN)。

代碼實現

復制代碼 代碼如下:

#include <iostream>
using namespace std;
 
//將有二個有序數列a[first...mid]和a[mid...last]合并。
void mergearray(int a[], int first, int mid, int last, int temp[])
{
     int i = first, j = mid + 1;
     int m = mid,   n = last;
     int k = 0;
 
     while (i <= m && j <= n)
     {
          if (a[i] <= a[j])
               temp[k++] = a[i++];
          else
               temp[k++] = a[j++];
     }
 
     while (i <= m)
          temp[k++] = a[i++];
 
     while (j <= n)
          temp[k++] = a[j++];
 
     for (i = 0; i < k; i++)
          a[first + i] = temp[i];
}
void mergesort(int a[], int first, int last, int temp[])
{
     if (first < last)
     {
          int mid = (first + last) / 2;
          mergesort(a, first, mid, temp);    //左邊有序
          mergesort(a, mid + 1, last, temp); //右邊有序
          mergearray(a, first, mid, last, temp); //再將二個有序數列合并
     }
}
 
bool MergeSort(int a[], int n)
{
     int *p = new int[n];
     if (p == NULL)
          return false;
     mergesort(a, 0, n - 1, p);
     delete[] p;
     return true;
}
 
int main()
{
     int arr[] = {2, 1, 4};
     MergeSort(arr, 3);
 
     for (int i = 0; i < 3; ++i)
     {
          cout<<arr[i]<<" ";
     }
     cout<<endl;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桐梓县| 夏津县| 东至县| 文登市| 天津市| 获嘉县| 镇沅| 潮安县| 昭苏县| 黄大仙区| 丰宁| 吉林省| 乌兰县| 山东省| 临沂市| 托克逊县| 大足县| 嘉荫县| 乐山市| 溧阳市| 镇康县| 堆龙德庆县| 芮城县| 长宁县| 上蔡县| 秭归县| 嘉禾县| 水城县| 光泽县| 广饶县| 松江区| 合江县| 寿光市| 巴中市| 长子县| 凤冈县| 蕉岭县| 临高县| 丹寨县| 九龙坡区| 勐海县|