Problem Description 题目链接 世界上存在着N个国家,简单起见,编号从0~N-1,假如a国和b国是盟国,b国和c国是盟国,那么a国和c国也是盟国。另外每个国家都有权宣布退盟(注意,退盟后还可以再结盟)。 定义下面两个操作: “M X Y” :X国和Y国结盟 “S X” :X国宣布退 ...
分类:
其他好文 时间:
2020-04-17 12:47:40
阅读次数:
75
struct union_find_set { int father[MAXN];//每个元素的祖先 union_find_set(int limit)//构造函数,对于每一个元素,其父亲初始化为它本身 { for(int i=1;i<=limit;i++) { father[i]=i; } } i ...
分类:
其他好文 时间:
2020-04-08 22:47:17
阅读次数:
89
这是一个非常经典的带权并查集,有两种写法。 1 边权并查集 规定一下,当x和y这条边的权值为0时,表示x和y是同类,当为1时,表示x吃y,当为2时,表示x被y吃。 一共有三种状态,如图,当A吃B,B吃C时,C必须吃A,路径压缩后,A被C吃。 然后就是带权并查集的模板了。 判断条件,当x和y在同一颗树 ...
分类:
其他好文 时间:
2020-04-08 22:17:26
阅读次数:
73
547. 朋友圈 难度中等204 班上有 N 名学生。其中有些人是朋友,有些则不是。他们的友谊具有是传递性。如果已知 A 是 B 的朋友,B 是 C 的朋友,那么我们可以认为 A 也是 C 的朋友。所谓的朋友圈,是指所有朋友的集合。 给定一个 N * N 的矩阵 M,表示班级中学生之间的朋友关系。如 ...
分类:
其他好文 时间:
2020-04-03 20:03:56
阅读次数:
60
唔,并查集是我掌握的比较好的一个东西(因为那次怒砍零分给我的印象真的太太太深刻了!) 例行安利:度娘搜一下并查集,有一个关于武侠的故事很有意思 并查集: 1.找父亲:直接一个get函数就行啦(路径压缩:在加入每一个新节点时,把他放进最爸爸的那个节点那里,让他成为别人的直系下属) 2.merge:直接 ...
分类:
其他好文 时间:
2020-03-30 23:46:14
阅读次数:
112
Tips: 这种数据如果没有路径压缩的话是很容易超时的。 5001 2 1 2 2 3 4 2 5 6 …… 2 9997 9998 2 9999 10000 5000 1 3 5 …… 9997 9999 10000 10000 10000 …… 10000 10000 ${O_{\left( n ...
分类:
其他好文 时间:
2020-03-17 12:42:21
阅读次数:
61
一、场景 并查集多数是用来解决连通性问题的 如至少修建几条路可以使所有路口可以相通 把互通的路口当做一个群组,那问题就是有几个这样的群组 如有N个群组 那至少修N-1条路 就可以把所有路口相连。 二、使用 并查集分两步 1、合并 合并就是把相连的多个节点划到一个群组中 可以定义数组parent[] ...
分类:
其他好文 时间:
2020-03-16 23:47:39
阅读次数:
87
int superior[MAXN]; int find_root(int son) { // int temp=son; // while(son!=superior[son]) // son=superior [son]; // superior[temp]=son;//路径压缩 // retu ...
分类:
其他好文 时间:
2020-03-15 13:29:04
阅读次数:
40
分块+并查集,大板子,没了。 并查集不路径压缩,可撤销,然后暴力删除 这样对于每个块都是独立的,所以直接搞就行了。 然后块内修改操作搞掉,就是单独的了 ...
不知道说些啥 #include<bits/stdc++.h> using namespace std; const int N=500010; int f[N]; int dep[N],siz[N]; int n,m; int F(int x){//递归版路径压缩 if(f[x]==x)return ...
分类:
其他好文 时间:
2020-02-07 18:45:01
阅读次数:
54