社区讨论

50分归并代码求调

P1908逆序对参与者 2已保存回复 2

讨论操作

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

当前回复
2 条
当前快照
1 份
快照标识符
@lo2rtceo
此快照首次捕获于
2023/10/23 18:44
2 年前
此快照最后确认于
2023/10/23 18:44
2 年前
查看原帖
rt,用裸的归并排序改了改,WA了后10个点
CPP
#include<bits/stdc++.h>
using namespace std;
int a[5000005];
int ans=0;
void msort(int s,int t)
{
	int r[5000005];
	if(s==t) return;
	int m=(s+t)/2;
	msort(s,m); 
	msort(m+1,t);
	int i=s,j=m+1,k=s;
	while(i<=m&&j<=t)
	{
		if(a[i]<=a[j])
		{
			r[k]=a[i];
			k++; i++;
		}
		else
		{
			r[k]=a[j];
			k++; j++;
			ans+=m-i+1; 
		}
	}
	while(i<=m)
	{
		r[k]=a[i];
		k++; i++;
	}
	while(j<=t)
	{
		r[k]=a[j];
		k++; j++;
	}
	for(int i=s;i<=t;i++)
		a[i]=r[i];
	return ;
}
int main()
{
	int b;
	scanf("%d",&b);
	for(int i=1;i<=b;i++)
		scanf("%d",&a[i]);
	msort(1,b);
	printf("%d ",ans);
	return 0;
}
数组肯定开的够大了吧...

回复

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

正在加载回复...