【BZOJ】【P1455】【罗马游戏】【题解】【斜堆】
来源:互联网 发布:神经网络算法入门书籍 编辑:程序博客网 时间:2024/05/02 04:39
传送门:http://www.lydsy.com:808/JudgeOnline/problem.php?id=1455
其实我发现fhqTreap和斜堆的merge似乎是一样的……
Code:
#include<bits/stdc++.h>using namespace std;const int maxn=1000010;int fa[maxn],n,m;int find(int x){if(fa[x]!=x)return fa[x]=find(fa[x]);return x;}bool die[maxn];struct node;node *Null,*root[maxn];struct node{node* c[2];int val,ind;node(int _val=0,int _ind=0){val=_val;c[0]=c[1]=Null;ind=_ind;}};node* merge(node *p,node *q){if(p==Null)return q;if(q==Null)return p;if(p->val>q->val)swap(p,q);p->c[1]=merge(p->c[1],q);swap(p->c[0],p->c[1]);return p;}void deb(node *x){if(x==Null)return;printf("%d ",x->val);deb(x->c[0]);deb(x->c[1]);}int main(){scanf("%d",&n);Null=new node(0);Null->c[0]=Null->c[1]=Null;for(int i=1;i<=n;i++)fa[i]=i;for(int i=1;i<=n;i++){int x;scanf("%d",&x);root[i]=new node(x,i);}scanf("%d",&m);while(m--){char opt[2];scanf("%s",&opt);if(opt[0]=='M'){int a,b;scanf("%d%d",&a,&b);if(die[a]||die[b])continue;a=find(a);b=find(b);if(a==b)continue;root[a]=root[b]=merge(root[a],root[b]);fa[find(b)]=find(a);}else{int x;scanf("%d",&x);if(die[x]||root[find(x)]==Null)puts("0");else{x=find(x);die[root[x]->ind]=1;printf("%d\n",root[x]->val);root[x]=merge(root[x]->c[0],root[x]->c[1]);}}}return 0;}
0 0
- 【BZOJ】【P1455】【罗马游戏】【题解】【斜堆】
- BZOJ 1455 罗马游戏 可并堆
- BZOJ 1455: 罗马游戏 可并堆
- BZOJ[1455]罗马游戏 可并堆
- BZOJ 1455 罗马游戏 可并堆裸
- bzoj 1455: 罗马游戏(可并堆)
- BZOJ 1455 罗马游戏【可并堆+并查集
- BZOJ 1455 罗马游戏
- BZOJ 1455 罗马游戏
- bzoj 1455 罗马游戏
- BZOJ 1455 罗马游戏 左偏树
- bzoj 1455: 罗马游戏 左偏树
- BZOJ 1455: 罗马游戏 左偏树裸题
- 【BZOJ】1455 罗马游戏 左偏树
- BZOJ 1455: 罗马游戏 左偏树 or pb_ds
- bzoj 1455 罗马游戏 解题报告
- bzoj 1455: 罗马游戏 左偏树入门
- bzoj 1455 && tyvj 2349 罗马游戏
- 最长回文字串--------注意一个小点-----添加字符的问题
- java面试题及答案(基础题122道,代码题19道)
- STL 源码剖析 算法 stl_algo.h -- next_permutation
- 太容易让他一人太诱人
- poj 1787(多重背包)
- 【BZOJ】【P1455】【罗马游戏】【题解】【斜堆】
- 有了无线网卡驱动,但总是安装不成功的解决办法
- 路由器端口映射
- Vs2013编译Boost asio时出现的错误
- poj 2244 Eeny Meeny Moo 约瑟夫环
- sizeof memset strlen 几个常见小错误 小结
- POJ 1573 Robot Motion 搜索
- 无向图的割顶和桥、无向图的双连通分量、有向图的强连通分量
- 10 款最好的远程桌面软件