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;
}

浙公网安备 33010602011771号