提交记录 9320


用户 题目 状态 得分 用时 内存 语言 代码长度
yussgrw noip17f. 【NOIP2017】列队 Accepted 100 599.632 ms 66040 KB C++ 3.59 KB
提交时间 评测时间
2019-04-30 18:20:14 2020-08-01 01:36:41
// luogu-judger-enable-o2
#include <cstdio>
#include <cstdlib>

const int MAXN=300000+5,MAXM=MAXN*5,p=19260817;
struct FHQTreap {
    int l,r,size,ran;
    long long s,e,cnt;
} t[MAXM],t2[MAXM];
int root[MAXN];
int ind=0,ind2=0,rt=0;

inline void update(int x) {
    t[x].size=t[t[x].l].size+t[t[x].r].size+1;
    t[x].cnt=t[t[x].l].cnt+t[t[x].r].cnt+t[x].e-t[x].s+1;
}

inline void update2(int x) {
    t2[x].size=t2[t2[x].l].size+t2[t2[x].r].size+1;
}

void split(int x, long long v, int &a, int &b) {
    if(!x) {
        a=0;
        b=0;
        return;
    }
    if(v<=t[t[x].l].cnt) {
        b=x;
        split(t[x].l,v,a,t[x].l);
    } else {
        a=x;
        v-=t[t[x].l].cnt+t[x].e-t[x].s+1;
        if(v<=0) {
            b=t[x].r;
            t[x].r=0;
        } else {
            split(t[x].r,v,t[x].r,b);
        }
    }
    update(x);
}

void splits(int x, int v, int &a, int &b) {
    if(!x) {
        a=0;
        b=0;
        return;
    }
    if(v<=t[t[x].l].size) {
        b=x;
        splits(t[x].l,v,a,t[x].l);
    } else {
        a=x;
        splits(t[x].r,v-t[t[x].l].size-1,t[x].r,b);
    }
    update(x);
}

int merge(int a, int b) {
    if(!a||!b) {
        return a+b;
    }
    if(t[a].ran<t[b].ran) {
        t[a].r=merge(t[a].r,b);
        update(a);
        return a;
    } else {
        t[b].l=merge(a,t[b].l);
        update(b);
        return b;
    }
}

inline int newnode(long long s, long long e) {
    int x=++ind;
    t[x].ran=rand();
    t[x].size=1;
    t[x].s=s;
    t[x].e=e;
    t[x].cnt=e-s+1;
    return x;
}

void split2(int x, int v, int &a, int &b) {
    if(!x) {
        a=0;
        b=0;
        return;
    }
    if(v<=t2[t2[x].l].size) {
        b=x;
        split2(t2[x].l,v,a,t2[x].l);
    } else {
        a=x;
        split2(t2[x].r,v-t2[t2[x].l].size-1,t2[x].r,b);
    }
    update2(x);
}

int merge2(int a, int b) {
    if(!a||!b) {
        return a+b;
    }
    if(t2[a].ran<t2[b].ran) {
        t2[a].r=merge2(t2[a].r,b);
        update2(a);
        return a;
    } else {
        t2[b].l=merge2(a,t2[b].l);
        update2(b);
        return b;
    }
}

inline int newnode2(long long s) {
    int x=++ind2;
    t2[x].ran=rand();
    t2[x].size=1;
    t2[x].s=s;
    return x;
}

long long solve1(int x, int y) {
    int a=0,b=0,c=0,v;
    long long ans;
    split(root[x],y,a,c);
    splits(a,t[a].size-1,a,b);
    v=y-t[a].cnt;
    ans=t[b].s+v-1;
    if(t[b].cnt==1) {
        root[x]=merge(a,c);
    } else {
        if(v==1) {
            t[b].s++;
            t[b].cnt--;
            root[x]=merge(merge(a,b),c);
        } else if(v==t[b].cnt) {
            t[b].e--;
            t[b].cnt--;
            root[x]=merge(merge(a,b),c);
        } else {
            root[x]=merge(a,newnode(t[b].s,t[b].s+v-2));
            root[x]=merge(root[x],newnode(t[b].s+v,t[b].e));
            root[x]=merge(root[x],c);
        }
    }
    a=b=c=0;
    split2(rt,x,a,c);
    split2(a,x-1,a,b);
    root[x]=merge(root[x],newnode(t2[b].s,t2[b].s));
    rt=merge2(merge2(a,c),newnode2(ans));
    return ans;
}

long long solve2(int x, int y) {
    int a=0,b=0,c=0;
    long long ans;
    split2(rt,x,a,c);
    split2(a,x-1,a,b);
    ans=t2[b].s;
    rt=merge2(merge2(a,c),b);
    return ans;
}

int main() {
    srand(p);
    int Q;
    long long N,M,i;
    scanf("%lld%lld%d",&N,&M,&Q);
    int x,y;
    for(i=1;i<=N;i++) {
        root[i]=newnode((i-1)*M+1,i*M-1);
        rt=merge2(rt,newnode2(i*M));
    }
    for(i=1;i<=Q;i++) {
        scanf("%d%d",&x,&y);
        if(y==M) {
            printf("%lld\n",solve2(x,y));
        } else {
            printf("%lld\n",solve1(x,y));
        }
    }
    return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #1414.38 us180 KBAcceptedScore: 5

Testcase #2388.94 us176 KBAcceptedScore: 5

Testcase #3388.31 us176 KBAcceptedScore: 5

Testcase #4406.05 us180 KBAcceptedScore: 5

Testcase #5399.82 us180 KBAcceptedScore: 5

Testcase #6412.67 us180 KBAcceptedScore: 5

Testcase #72.793 ms3 MB + 812 KBAcceptedScore: 5

Testcase #82.791 ms3 MB + 804 KBAcceptedScore: 5

Testcase #93.021 ms4 MB + 116 KBAcceptedScore: 5

Testcase #102.757 ms3 MB + 728 KBAcceptedScore: 5

Testcase #1192.613 ms10 MB + 48 KBAcceptedScore: 5

Testcase #1290.557 ms9 MB + 1012 KBAcceptedScore: 5

Testcase #13360.376 ms30 MB + 480 KBAcceptedScore: 5

Testcase #14333.017 ms29 MB + 144 KBAcceptedScore: 5

Testcase #15417.707 ms52 MB + 28 KBAcceptedScore: 5

Testcase #16437.449 ms53 MB + 256 KBAcceptedScore: 5

Testcase #17151.014 ms21 MB + 520 KBAcceptedScore: 5

Testcase #18144.206 ms20 MB + 916 KBAcceptedScore: 5

Testcase #19588.893 ms63 MB + 428 KBAcceptedScore: 5

Testcase #20599.632 ms64 MB + 504 KBAcceptedScore: 5


Judge Duck Online | 评测鸭在线
Server Time: 2024-05-06 03:01:22 | Loaded in 2 ms | Server Status
个人娱乐项目,仅供学习交流使用