社区讨论
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 条回复,欢迎继续交流。
正在加载回复...