P2717

105,一眼nlogn。
考虑能不能写线段树(毕竟我只会这一种树状结构)。
发现很难想……
看来得靠分治了
复习一手CDQ
???
看了一眼题解
原来,我只是没想到前缀和,嘤嘤嘤
然后就成归并排序求逆序对了,只不过要加上0
然而90pts???
不开ll见祖宗啊……
简单放个代码

#include<bits/stdc++.h>
using namespace std;
int a[100010],t[100010];
long long ans;
void cdq(int l,int r){
	if(l==r)return;
	int mid=(l+r)>>1,i=l,j=mid+1,k=l;
	cdq(l,mid);cdq(j,r);
	for(;j<=r;){
		while(i<=mid&&a[i]<=a[j])t[k++]=a[i++];
		t[k++]=a[j++];
		ans+=i-l;
	}
	for(;i<=mid;)t[k++]=a[i++];
	for(i=l;i<=r;++i)a[i]=t[i];
}
int main() {
	int n,k;
	cin>>n>>k;
	for(int i=1;i<=n;i++){
		cin>>a[i];
		a[i]-=k;
		a[i]+=a[i-1];
	}
	cdq(0,n);
	cout<<ans;
	return 0;
}
posted @ 2025-02-27 19:09  yzc_is_SadBee  阅读(12)  评论(0)    收藏  举报