社区讨论

FHQ Treap 复杂度假吗

P9741 「KDOI-06-J」翻转与反转参与者 3已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@m260etzd
此快照首次捕获于
2024/10/12 18:24
去年
此快照最后确认于
2025/11/04 17:22
4 个月前
查看原帖
rt,50pts,赛场上只想出了这个(打数据结构打的)
尽量卡常了,2e6 复杂度应该假不了吧
CPP
#include<bits/stdc++.h>
using namespace std;
const int MAXN=2000005;
int n,rt=0,cnt=0;
mt19937 rnd(114514u);
struct Treap{
    int l,r,p,sz;
    bool x,tag1,tag2;
    // tag1下标,tag2值
}t[MAXN];
inline void pushup(int x){
    t[x].sz=t[t[x].l].sz+t[t[x].r].sz+1;
}
inline void pushdown(int x){
    if(t[x].tag1){
        swap(t[x].l,t[x].r);
        t[t[x].l].tag1^=1;
        t[t[x].r].tag1^=1;
        t[x].tag1=0;
    }
    if(t[x].tag2){
        t[x].x^=1;
        t[t[x].l].tag2^=1;
        t[t[x].r].tag2^=1;
        t[x].tag2=0;
    }
}
inline void newnode(int x){
    t[++cnt].x=x;
    t[cnt].p=rnd();
    t[cnt].l=t[cnt].r=0;
    t[cnt].sz=1;
    t[cnt].tag1=t[cnt].tag2=0;
}
inline void split(int x,int w,int &l,int &r){
    if(!x)
        return (void)(l=r=0);
    pushdown(x);
    if(t[t[x].l].sz+1<=w)
        l=x,split(t[x].r,w-t[t[x].l].sz-1,t[x].r,r);
    else
        r=x,split(t[x].l,w,l,t[x].l);
    pushup(x);
}
inline int merge(int l,int r){
    if(!l||!r)
        return l|r;
    if(t[l].p>t[r].p){
        pushdown(l);
        t[l].r=merge(t[l].r,r);
        pushup(l);
        return l;
    }else{
        pushdown(r);
        t[r].l=merge(l,t[r].l);
        pushup(r);
        return r;
    }
}
inline void output(int x){
    if(!x)
        return ;
    pushdown(x);
    output(t[x].l);
    printf("%d ",t[x].x);
    output(t[x].r);
}
signed main(){
    scanf("%d",&n);
    for(int i=1,k;i<=n;++i){
        scanf("%d",&k);
        newnode(k);
        rt=merge(rt,cnt);
    }
    // output(rt);
    // printf("\n");
    for(int i=1,l,r;i<=n;++i){
        split(rt,i,l,r);
        t[l].tag1^=1;
        t[l].tag2^=1;
        rt=merge(l,r);
    }
    output(rt);
    return 0;
}

回复

3 条回复,欢迎继续交流。

正在加载回复...