[USACO17JAN]Balanced Photo平衡的照片 (树状数组)

题目链接

Solution

先离散化,然后开一个大小为 \(100000\) 的树状数组记录前面出现过的数。
然后查询 \((h[i],n]\) 即可.
还要前后各做一遍。

Code

#include<bits/stdc++.h>
#define N 200008
#define ll long long
using namespace std;

void in(ll &x)
{
    char ch=getchar();ll f=1,w=0;
    while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
    while(ch<='9'&&ch>='0'){w=w*10+ch-'0';ch=getchar();}
    x=f*w; return;
}

ll h[N],c[N],a[N],n;
ll L[N],R[N],ans;

ll lowbit(ll x){return x&(-x);}
void insert(int x)
{for(int i=x;i<=n;i+=lowbit(i))c[i]++;}
ll query(int x)
{ll ans=0;for(int i=x;i>=1;i-=lowbit(i))ans+=c[i];return ans;}

int main()
{
    //freopen("a.in","r",stdin);
    in(n);
    for(int i=1;i<=n;i++)in(h[i]),a[i]=h[i];
    sort(a+1,a+n+1);
    for(int i=1;i<=n;i++)
    h[i]=lower_bound(a+1,a+n+1,h[i])-a;
    for(int i=1;i<=n;i++)
        L[i]=query(n)-query(h[i]),insert(h[i]);
    memset(c,0,sizeof(c));
    for(int i=n;i>=1;i--)
        R[i]=query(n)-query(h[i]),insert(h[i]);
    for(int i=1;i<=n;i++)
    {
        ll x=L[i],y=R[i];
        if(x<y)swap(x,y);
        if(x==y)continue;
        if(x>y*2)ans++;
    }cout<<ans<<endl;
}
posted @ 2019-07-23 18:43  Kevin_naticl  阅读(175)  评论(0编辑  收藏  举报