【模板】可持久化并查集

题目链接

题目描述

给定 nnn 个集合,第 iii 个集合内初始状态下只有一个数,为 iii

mmm 次操作。操作分为 333 种:

  • 1 a b 合并 a,ba,ba,b 所在集合;

  • 2 k 回到第 kkk 次操作(执行三种操作中的任意一种都记为一次操作)之后的状态;

  • 3 a b 询问 a,ba,ba,b 是否属于同一集合,如果是则输出 1 ,否则输出 0

输入格式

第一行两个整数,n,mn,mn,m

接下来 mmm 行,每行先输入一个数 optoptopt。若 opt=2opt=2opt=2 则再输入一个整数 kkk,否则再输入两个整数 a,ba,ba,b,描述一次操作。

输出格式

对每个操作 333,输出一行一个整数表示答案。

输入输出样例

输入 #1

5 6
1 1 2
3 1 2
2 0
3 1 2
2 1
3 1 2

输出 #1

1
0
1

说明/提示

对于 100%100\%100% 的数据,1≤n≤105,1≤m≤2×1051\le n\le 10^5,1\le m\le 2\times 10^51n1051m2×105


Solution

  • 模板题,可以通过 可持久化数组 +++ 启发式合并 /// 按秩合并 实现。

Code

#include<cstdio>
#include<algorithm>
using namespace std;
const int maxn=300010;
struct SegmentTree{int lc,rc,l,r,fa,siz;
}tr[maxn*40];
int n,m,tot,root[maxn];
inline int build(int l,int r){int u=++tot,mid=(l+r)>>1;tr[u].l=l;tr[u].r=r;if(l==r){tr[u].fa=l;tr[u].siz=1;return u;}tr[u].lc=build(l,mid);tr[u].rc=build(mid+1,r);return u;
}
inline int query(int u,int a){if(tr[u].l==tr[u].r)return u;int mid=(tr[u].l+tr[u].r)>>1;if(a<=mid)return query(tr[u].lc,a);else return query(tr[u].rc,a);
}
inline int find(int v,int x){int p=query(root[v],x);return tr[p].fa==x?x:find(v,tr[p].fa);
}
inline int merge(int p,int pos,int fa){int u=++tot;tr[u].l=tr[p].l;tr[u].r=tr[p].r;if(tr[u].l==tr[u].r){tr[u].fa=fa;return u;}int mid=(tr[u].l+tr[u].r)>>1;if(pos<=mid){tr[u].rc=tr[p].rc;tr[u].lc=merge(tr[p].lc,pos,fa);}else{tr[u].lc=tr[p].lc;tr[u].rc=merge(tr[p].rc,pos,fa);}return u;
}
inline int add(int p,int pos,int d){int u=++tot;tr[u].l=tr[p].l;tr[u].r=tr[p].r;if(tr[u].l==tr[u].r){tr[u].fa=tr[p].fa;tr[u].siz=tr[p].siz+d;return u;}int mid=(tr[u].l+tr[u].r)>>1;if(pos<=mid){tr[u].rc=tr[p].rc;tr[u].lc=add(tr[p].lc,pos,d);}else{tr[u].lc=tr[p].lc;tr[u].rc=add(tr[p].rc,pos,d);}return u;
}
int main(){scanf("%d%d",&n,&m);root[0]=build(1,n);for(int i=1;i<=m;++i){int opt,a,b;scanf("%d",&opt);if(opt==1){scanf("%d%d",&a,&b);a=find(i-1,a);b=find(i-1,b);if(a==b){root[i]=root[i-1];continue;}int x=query(root[i-1],a),y=query(root[i-1],b);if(tr[x].siz>tr[y].siz)swap(x,y),swap(a,b);root[i]=merge(root[i-1],a,b);root[i]=add(root[i],b,tr[x].siz);}else if(opt==2){scanf("%d",&a);root[i]=root[a];}else{scanf("%d%d",&a,&b);root[i]=root[i-1];printf("%d\n",find(i,a)==find(i,b));}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/318484.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P1758-[NOI2009]管道取珠【dp】

正题 题目链接:https://www.luogu.com.cn/problem/P1758 题目大意 给出一个大小为nnn和一个大小为mmm的栈&#xff0c;每次选择一个栈弹出栈顶然后记录这个字母&#xff0c;求所有弹出序列的弹出方案的二次方和。 1≤n,m≤5001\leq n,m\leq 5001≤n,m≤500 解题思路 二次方和…

洛谷P2680:运输计划(倍增、二分、树上差分)

传送门 文章目录题目描述解析问题代码题目描述 解析 求最大值的最小值 容易想到二分 然后。。。就没有然后了。。。 看了题解 学会了一个新技能&#xff1a;树上差分 &#xff08;其实学长之前好像讲过。。。&#xff09; 一般的&#xff0c;对于一条A到B的路径&#xff0c;如…

Loj#2880-「JOISC 2014 Day3」稻草人【CDQ分治,单调栈,二分】

正题 题目链接:https://loj.ac/problem/2880 题目大意 给出平面上的nnn个点&#xff0c;然后求有多少个矩形满足 左下角和右上角各有一个点矩形之间没有其他点 1≤n≤2105,1≤xi,yi≤109,1\leq n\leq 2\times 10^5,1\leq x_i,y_i\leq 10^9,1≤n≤2105,1≤xi​,yi​≤109,保证…

计算几何基础-2

文章目录直线&#xff1a;图形&#xff1a;求垂足求两圆交点直线与圆交点多边形问题判断一个点是否在任意多边形内部Pick定理凸包求点集的凸包水平法&#xff1a;增量法&#xff1a;半平面半平面交求半平面交直线&#xff1a; struct Line{point p,v;Line(){}Line(point _p.po…

eShopOnContainers 看微服务 ②:配置 启动

一、什么是dockerDocker 是一个开源项目&#xff0c;通过把应用程序打包为可移植的、自给自足的容器&#xff08;可以运行在云端或本地&#xff09;的方式&#xff0c;实现应用程序的自动化部署。使用 Docker 的时候&#xff0c;需要创建一个应用或服务&#xff0c;然后把它和它…

字符串距离(opj )(动态规划)

题目描述2988:计算字符串距离 对于两个不同的字符串&#xff0c;我们有一套操作方法来把他们变得相同&#xff0c;具体方法为&#xff1a; 修改一个字符&#xff08;如把“a”替换为“b”&#xff09;删除一个字符&#xff08;如把“traveling”变为“travelng”&#xff09;…

2021牛客暑期多校训练营9C-Cells【LGV引理,范德蒙德行列式】

正题 题目链接:https://ac.nowcoder.com/acm/contest/11260/C 题目大意 一个平面上&#xff0c;nnn个起点(0,ai)(0,a_i)(0,ai​)分别对应终点(i,0)(i,0)(i,0)&#xff0c;每次只能往上或者往左走。求不交路径数。 1≤n≤5105,ai<ai1,an≤1061\leq n\leq 5\times 10^5,a_i&…

[ZJOI2010]网络扩容[网络流24题]

[ZJOI2010]网络扩容[网络流24题] 题意&#xff1a; 给定一张有向图&#xff0c;每条边都有一个容量 c 和一个扩容费用 w。这里扩容费用是指将容量扩大 1 所需的费用。求&#xff1a; 在不扩容的情况下&#xff0c;1 到 n 的最大流&#xff1b; 将 1 到 n 的最大流增加 k 所需…

判断整除(opj)(动态规划)

解析 与取模结合的动归&#xff0c;正常做即可 问题 眼瞎&#xff01;&#xff01;&#xff01; 这个序列的每个数都必须用到&#xff01;&#xff01;&#xff01; if(f[i-1][j]) f[i][j]1;上面这行就是不对的&#xff01;&#xff01;&#xff01; 头疼 仔细审题 opj的题…

[CF850F] Rainbow Balls

题目链接 题目描述 给定 nnn 种颜色的球&#xff0c;每种球有 aia_iai​ 个&#xff0c;对这些球执行以下操作&#xff1a; 有顺序地任意取两个球&#xff0c;将第二个球涂上第一个球的颜色&#xff0c;重复该操作至所有球颜色相同。 求期望操作次数&#xff0c;对 109710^9…

[USACO09FEB]Revamping Trails G

题意&#xff1a; 约翰一共有 N 个牧场.由 MM 条布满尘埃的小径连接。小径可以双向通行。每天早上约翰从牧场 1 出发到牧场 N 去给奶牛检查身体。 通过每条小径都需要消耗一定的时间。约翰打算升级其中 K 条小径&#xff0c;使之成为高速公路。在高速公路上的通行几乎是瞬间完…

NET Core微服务之路:自己动手实现Rpc服务框架,基于DotEasy.Rpc服务框架的介绍和集成...

本篇内容属于非实用性&#xff08;拿来即用&#xff09;介绍&#xff0c;如对框架设计没兴趣的朋友&#xff0c;请略过。 快一个月没有写博文了&#xff0c;最近忙着两件事;一&#xff1a;阅读刘墉先生的《说话的魅力》&#xff0c;以一种微妙的&#xff0c;你我大家都会经常遇…

AT4353-[ARC101D]Robots and Exits【LIS】

正题 题目链接:https://www.luogu.com.cn/problem/AT4353 题目大意 数轴上有nnn个球mmm个洞&#xff0c;每次可以将所有球左移或者右移&#xff0c;球到洞的位置会掉下去。 求有多少让球掉进不同洞的方案。 1≤n,m≤1051\leq n,m\leq 10^51≤n,m≤105 解题思路 设一个球距离…

花店橱窗布置(洛谷P1854)(动态规划)

传送门 文章目录解析问题代码解析 一道很正常的动态规划 dp[i][j]表示到第j个花瓶放了第j朵花的dp最优值 注意&#xff1a;是严格使第i朵放在j瓶 找到最优解递归输出即可 问题 又是初始化的问题&#xff01;&#xff01;&#xff01; 一开始把dp赋值成负无穷时落掉了j0的一行…

P4009 汽车加油行驶问题

题目描述&#xff1a; 题解&#xff1a; 看了很多题解&#xff0c;无论什么解法都绕不开分层图 在本题中加满油的车每次可以移动K步&#xff0c;那么我们就可以建立一个K1层的分层图&#xff0c;表示汽车油量k的状态&#xff08;油量0…k&#xff09;&#xff0c;然后根据题目…

P7294-[USACO21JAN]Minimum Cost Paths P【单调栈】

正题 题目链接:https://www.luogu.com.cn/problem/P7294 题目大意 nmn\times mnm的网格&#xff0c;当你在(x,y)(x,y)(x,y)时你有两种选择 花费x2x^2x2的代价向右移动花费cyc_ycy​的代价向下移动 qqq次询问(1,1)(1,1)(1,1)走到(x,y)(x,y)(x,y)的最小代价。 1≤n≤109,1≤m,q…

.net core i上 K8S(五).netcore程序的hostip模式

正文上一章讲了pod的管理&#xff0c;今天再分享一个pod的访问方式1.Pod的HostIP模式Pod的HostIP模式&#xff0c;可以通过宿主机访问pod内的服务&#xff0c;创建yaml文件如下apiVersion: v1 kind: Pod metadata: name: netcore-podlabels:app: netcorepod spec:containers: …

状态压缩:枚举子集(最优组队)(ybtoj)(动态规划)

解析 很裸的状压dp 但是直接暴力的话状态2n,枚举2n 乘在一起会T诶 怎么办呢&#xff1f; 使用下面这个循环&#xff0c;就可以保证只会枚举当前状态s的子集 for(int i(s-1)&s;i;i(i-1)&s){........ }证明 举举例子就挺明显了 为什么不重不漏呢&#xff1f; 首先i肯…

P7295-[USACO21JAN]Paint by Letters P【平面图欧拉公式】

正题 题目链接:https://www.luogu.com.cn/problem/P7295 题目大意 给出n∗mn*mn∗m的网格&#xff0c;每个格子上有字母&#xff0c;相同字母的四联通相邻格子为连通&#xff0c;每次询问一个子矩阵求连通块个数。 1≤n,m,q≤10001\leq n,m,q\leq 10001≤n,m,q≤1000 解题思路…

【活动(深圳)】告别2018之12.22 大湾区.NET Meet 大会 ,同时有网络直播

今年的 Connect(); 主题更加聚焦开发者工具生产力、开源&#xff0c;以及无服务器&#xff08;Serverless&#xff09;云服务。Visual Studio 2019 AI 智能加持的 IntelliCode、实时代码协作共享 Live Share&#xff0c;.NET Core 3.0的预览版本附带了大量更新&#xff0c;旨在…