#include<iostream>
using namespace std;
void Merge(int a[], int left, int center, int right)
{
int *t = new int[right-left+1];//存放被排序的元素
int i = left;
int j = center + 1;
int k = 0;
//合并数组,用插入排序,如果左边大就插入左边的数,右边的计数器等待,与下一个左边的数比较;右边大就插入右边的数,左边的计数器等待,与下一个右边的数比较(这里指的插入是插入到新数组t[])
while (i<=center && j<=right)
{
if (a[i] <= a[j])
t[k++] = a[i++];
else
t[k++] = a[j++];
}
//上面的步骤在执行完后,左或右边都有可能剩余若干个元素,而另一边的元素肯定已全部复制到新数组,这时需要特殊对待剩下的元素
if (i == center+1)
{
while (j <= right)
t[k++] = a[j++];
}
else
{
while (i <= center)
t[k++] = a[i++];
}
//把t[]的元素复制回a[]中left到right段
for (i=left,k=0; i<=right; i++,k++)
a[i] = t[k];
//释放内存
delete []t;
}
void MergeSort(int a[], int left, int right)
{
if (left < right)
{
int center = (left + right) / 2;//取得中点
//将原来序列分为两段
MergeSort(a, left, center);
MergeSort(a, center+1, right);
//合并刚才分开的两段,得到原来序列的有序序列
Merge(a, left, center, right);
}
}
int main()
{
int a[] = {2,1,2,6,4,8,9,79,120,12,32,21,45,12,4,2,6,8,7,4};
MergeSort(a,0,19);
for(int i=0;i<20;i++)
{
printf("%d ",a[i]);
}
}
排序之归并排序
最新推荐文章于 2024-05-15 07:36:10 发布