归并排序(递归实现)

归并排序(递归实现)

归并排序应该是稳定性排序中时间效率最高的算法

归并排序概述图:
在这里插入图片描述
如图,首先将一组序列递归拆分(分解)成多组,每组中只含一个元素。
之后再归并(merging函数即为归并过程)。

#include <stdio.h>
#include <stdlib.h>
#define maxsize 10 //排序序列长度

void merging(int *left,int leftsize,int right,int rightsize) //归并函数
{
int temp[maxsize]; //储存排好序后序列的临时数组
int i = 0,j = 0,k = 0,m; //注意这里的数组我们从下标0开始存储
while(i < leftsize&&j < rightsize) //当左右两组都没达到末端时进入循环
{
if(left[i] <= right[j]) temp[k++] = left[i++]; //左组元素小于等于右组元素,将左组元素存入temp[k],同时k++,i++
else temp[k++] = right[j++]; //右组元素小于左组元素,存右组元素
}
while (i < leftsize) temp[k++] = left[i++];
while (j < rightsize) temp[k++] = right[j++]; //根据归并排序的特性,在上述while循环结束后,左组或者右组末尾还存在元素未存入temp,故需这两步。并且不能用if,必须用while,想想为什么。
for( m = 0; m < (leftsize+rightsize); m++)
{
left[m] = temp[m];
} //将temp中的元素复制给left,这样下一次递归调用merging函数时,才能用到排好序的left,right。注意,这一步必不可少,否则导致排序失败

}

void mergesort(int k[],int n) //归并排序函数
{
if(n > 1) //递归出口(i = 1递归结束)
{
int *left = k;
int leftsize = n/2; //左组
int *right = &k[n/2];
int rightsize = n - leftsize; //右组
mergesort(left,leftsize);
mergesort(right,rightsize); //递归,继续将得到的左右两组分组,即“分解”过程
merging(left,leftsize,right,rightsize); //归并
}
}

int main() //主函数
{
int i;
int k[10] = {3,2,5,4,6,8,0,9,7,1};
mergesort(k,10);
for(i = 0;i < 10;i++)
{
printf("%d “,k[i]);
}
printf(”\n");
return 0;
}

运行结果如图:
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值