社区讨论

归并排序

学术版参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@lo3hfrzt
此快照首次捕获于
2023/10/24 06:41
2 年前
此快照最后确认于
2023/10/24 06:41
2 年前
查看原帖
代码如下
CPP
#include<bits/stdc++.h>
using namespace std;
int n,a[1005],b[1005];
void msort(int l,int r)
{
	if(l==r) return ;
	int mid=(l+r)/2;
	msort(l,mid);
	msort(mid+1,r);
	int i=l,j=mid+1,k=1;
	while(i<=mid&&j<=r)
	{
		if(a[i]<a[j])
		{
			b[k]=a[i];
			k++;
			i++;
		}
		else
		{
			b[k]=a[j];
			k++;
			j++;
		}
	}
	while(i<=mid)
	{
		b[k]=a[i];
		k++;
		i++;
	}
	while(j<=r)
	{
		b[k]=a[j];
		k++;
		j++;
	}
	for(int i=l;i<=r;i++)
		a[i]=b[i];
}
int main()
{
	cin>>n;
	for(int i=1;i<=n;i++)
		cin>>a[i];
	msort(1,n);
	for(int i=1;i<=n;i++)
		cout<<a[i]<<" ";
	return 0;
} 
为什么输入5 4 3 2 1会输出0 0 3 4 5? 哪位帮我调调。

回复

2 条回复,欢迎继续交流。

正在加载回复...