hdu1394Minimum Inversion Number树状数组求逆序对水题
//num[i]为输入时的数据
//ans[i]为m=i时的逆序数
//用树状数组求ans[0]的逆序对
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=5010;
int num[maxn];
int tree[maxn];
int lowbit(int i)
{
return i&(-i);
}
int getsum(int i)
{
int sum=0;
while(i>0)
{
sum+=tree[i];
i-=lowbit(i);
}
return sum;
}
void update(int i,int dx)
{
while(i<maxn)
{
tree[i]+=dx;
i+=lowbit(i);
}
}
int main()
{
int n;int i;
while(scanf("%d",&n)!=EOF)
{
memset(tree,0,sizeof(tree));
int ans[maxn];
memset(ans,0,sizeof(ans));
for(i=1;i<=n;i++)
{
scanf("%d",&num[i]);
num[i]++;
ans[0]+=(i-1)-getsum(num[i]);
update(num[i],1);
}
int sum=ans[0];
for(i=1;i<=n;i++)
{
ans[i]=ans[i-1]+(n+1)-2*num[i];
sum=min(ans[i],sum);
}
printf("%d\n",sum);
}
}
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。