LG5200「USACO2019JAN」スリーピー牛ソートフェンウィックツリー

\(\ mathrm {スリーピー牛ソート} \)

問題の説明

LG5200

問題の解決策

フェンウィックツリー。

セット\(C [i]が\)代表\([1、i]は\ ) 正規化された中央値。

もちろん、究極の目標は、その後、列挙を逆転、シーケンス全体が上昇シーケンスで並べ替える最初の注文した最後を挿入することです。

、動作周波数と、フロント左障害に直接出力を動作させます。

次のプログラムは、構築するのは簡単です。

\(\ mathrm {コード} \)

#include<bits/stdc++.h>
using namespace std;

void read(int &x){
    x=0;char ch=1;int fh;
    while(ch!='-'&&(ch>'9'||ch<'0')) ch=getchar();
    if(ch=='-') ch=getchar(),fh=-1;
    else fh=1;
    while(ch>='0'&&ch<='9') x=(x<<1)+(x<<3)+ch-'0',ch=getchar();
    x*=fh;
}

const int maxn=100000+7;
#define lowbit(pos) (pos&(-pos))

int c[maxn],n,a[maxn];

void change(int pos,int k){
    while(pos<=n){
        c[pos]+=k;pos+=lowbit(pos);
    }
}

int query(int pos){
    int ret=0;
    while(pos){
        ret+=c[pos];pos-=lowbit(pos);
    }
    return ret;
}

int ans,cnt;

int main(){
    freopen("sleepy.in","r",stdin);freopen("sleepy.out","w",stdout);
    read(n);
    for(int i=1;i<=n;i++) read(a[i]);
    for(int i=n;i>=1;i--){
        ans++;--cnt;change(a[i],1);
        if(a[i-1]>a[i]) break;
    }
    cnt+=n;
    printf("%d\n",cnt);
    for(int i=1;i<=n-ans;i++){
        --cnt;printf("%d ",query(a[i])+cnt);
        change(a[i],1);
    }
    fclose(stdin);fclose(stdout);
    return 0;
}

おすすめ

転載: www.cnblogs.com/liubainian/p/11566510.html