POJ 3270 / HDU 2838 - Cow Sorting

 

题目地址:  http://poj.org/problem?id=3270

 

       注意到了其中一部分需要__int64,另一部分被想当然的忽略了(以为不可能爆int)。结果WAn久不知原因。

 

       很经典的求逆序数题目。初学题。比基本的逆序数多了一个状态。即需要多写一个Query。

 

 

#include<iostream>
#include<cstdio>

using namespace std;

__int64 tree[100100];
__int64 num[100100];

int n;

__int64 s[100100];

__int64 query(__int64 val){
	__int64 sum=0;
	while(val>0){
		sum+=tree[val];
		val-=val&-val;
	}
	return sum;
}
__int64 query2(__int64 val){
	__int64 sum=0;
	while(val>0){
		sum+=num[val];
		val-=val&-val;
	}
	return sum;
}
void update(int val){
	__int64 temp=val;
	while(val<=n){
		tree[val]+=temp;
		num[val]++;
		val+=val&-val;
	}
}

int main(){
	int i;
	__int64 sum=0;
	while(~scanf("%d",&n)){
		sum=0;
		for(i=1;i<=n;i++)
			tree[i]=num[i]=0;
		for(i=1;i<=n;i++)
			scanf("%I64d",&s[i]);
		for(i=n;i>=1;i--){
			sum+=query(s[i]-1)+query2(s[i]-1)*s[i];
	//		printf("%d\n",s[i]);
			update(s[i]);
	//		cout<<"tree"<<": ";for(int j=1;j<=n;j++)printf("%3I64d",tree[j]);cout<<endl;
	//		cout<<"num "<<": ";for(int j=1;j<=n;j++)printf("%3d",num[j]);cout<<endl;
		}
		printf("%I64d\n",sum);
	}
	return 0;
}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值