排序算法分享:归并排序!
c、如下图所示,两个指针都指向了数字5,如果遇到两个数字一样的话,一般是把第一个序列的数字放到临时数组res里面去,这点稍微要注意一下
d、最后把临时数组里面的是数字放到原来的数组里面去
注意:一个算法稳定,并不能说它的时间效率是稳定的;这里的稳定是说两个序列中有两个数是相同的,如果在排完序之后,他们的位置还是没有发生变化的话,那么这个排序就是稳定的,反之亦然!
3、归并排序的平均时间复杂度的计算推导:
从图片的纵性来分析,当拆解到1的时候,这个时候什么数等于n除于它等于1,通过计算,我们知道是logn,然后再从横向分析,我们要最多比较n个数字,所以归并排序的时间复杂度就是:nlogn
二、代码示例:
代码:
#include <iostream>
using namespace std;
const int N = 1e5 + 10;
int n;
int q[N], tmp[N];
void merge_sort(int q[],int l, int r)
{
if(l>=r)return;//判断序列中是否为空或者只有一个数字,如果是的话,我们就不用排序了
//确定分界点
int mid = l + r >> 1;
//递归处理
merge_sort(q,l,mid);
merge_sort(q,mid+1,r);
//定义双指针
int k =0,i = l, j= mid+1;
//归并处理
while(i <= mid && j <= r)
if(q[i] < q[j])tmp[k++] = q[i++];
else
tmp[k++] = q[j++];
//把源数组中剩余的数字(注意这里的数字一定是最小的)放到临时数组后面去
while(i <= mid)tmp[k++] = q[i++];
while(j <= r)tmp[k++] = q[j++];
//把临时数组中排好序的数字放到源数组中去
for(i = l, j =0;i<=r;i++,j++)q[i]=tmp[j];
}
int main()
{
scanf("%d",&n);
for(int i = 0;i<n;i++)
{
scanf("%d",&q[i]);
}
merge_sort(q,0,n-1);
for(int i = 0; i<n;i++)
{
printf("%d ",q[i]);
}
return 0;
}
结果:
图片新闻
技术文库
最新活动更多
-
即日-12.26立即报名>>> 【在线会议】村田用于AR/VR设计开发解决方案
-
1月8日火热报名中>> Allegro助力汽车电气化和底盘解决方案优化在线研讨会
-
1月9日立即预约>>> 【直播】ADI电能计量方案:新一代直流表、EV充电器和S级电能表
-
即日-1.14火热报名中>> OFweek2025中国智造CIO在线峰会
-
即日-1.20限时下载>>> 爱德克(IDEC)设备及工业现场安全解决方案
-
即日-1.24立即参与>>> 【限时免费】安森美:Treo 平台带来出色的精密模拟
推荐专题
发表评论
请输入评论内容...
请输入评论/评论长度6~500个字
暂无评论
暂无评论