并查集运用 野性酷女 2022-06-17 13:59 120阅读 0赞 来点心得体会吧! intFind(int x) \{ return x==fa\[x\]?x:fa\[x\]=Find(fa\[x\]); \} voidmerger(int a,int b) \{ int r1 = Find(a); int r2 = Find(b); /\*if(r1!=r2) \{ Fa\[r1\]=r2; \} \*/ if(r1>r2) fa\[r2\]=r1; else if (r1<r2) fa\[r1\]=r2; 此处两者的区别在于后者可以使得在整个家族里边的人都以最大(或最小,只要改下大于号和小于号即可)的为祖先; 比如1,2,3,4,5,6,7,8,9,10;是一个家族,则10(或1)是这个家族的祖先;即Find(1,2,3,4,5,6,7,8,9,10)都等于10(或者1); \} **此外,对于并查集,如果a,b,c,d,e,f…等是同一个家族的话,会发现所有** **Find(a)=Find(b)=Find(c)=Find(d)=Find(e)=Find(f)=Find(fa\[a\])** **=Find(fa\[b\])=Find(fa\[c\])=Find(fa\[d\])=Find(fa\[e\])=Find(fa\[f\])=…….** 布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位。无论如何,总不能把两个死对头排到同一张宴会桌旁!这个艰巨任务现在就交给你,对任何一对客人,请编写程序告诉主人他们是否能被安排同席。 **输入格式:** 输入第一行给出3个正整数:N(<= 100),即前来参宴的宾客总人数,则这些人从1到N编号;M为已知两两宾客之间的关系数;K为查询的条数。随后M行,每行给出一对宾客之间的关系,格式为:“宾客1 宾客2 关系”,其中“关系”为1表示是朋友,\-1表示是死对头。注意两个人不可能既是朋友又是敌人。最后K行,每行给出一对需要查询的宾客编号。 这里假设朋友的朋友也是朋友。但敌人的敌人并不一定就是朋友,朋友的敌人也不一定是敌人。只有单纯直接的敌对关系才是绝对不能同席的。 **输出格式:** 对每个查询输出一行结果:如果两位宾客之间是朋友,且没有敌对关系,则输出“No problem”;如果他们之间并不是朋友,但也不敌对,则输出“OK”;如果他们之间有敌对,然而也有共同的朋友,则输出“OK but...”;如果他们之间只有敌对关系,则输出“No way”。 **输入样例:** 7 8 4 5 6 1 2 7 -1 1 3 1 3 4 1 6 7 -1 1 2 1 1 4 1 2 3 -1 3 4 5 7 2 3 7 2 **输出样例:** No problem OK OK but... No way #include<cstdio> #include<iostream> #include<string> #include<algorithm> using namespace std; int f[101],map[101][101]; int find(int x) { return f[x]==x?x:f[x]=find(f[x]); } void merge(int a,int b) { a=find(a);//还可以写成a=find(f[a]); b=find(b); //还可以写成b=find(f[b]); if(a!=b) f[a]=b; } int main() { int n,m,k,x,y,z; scanf("%d %d %d",&n,&m,&k); for(int i=0;i<=n;i++) f[i]=i; for(int i=0;i<m;i++) { scanf("%d %d %d",&x,&y,&z); map[y][x]=map[x][y]=z; if(z==1) merge(x,y); } for(int i=0;i<k;i++) { scanf("%d %d",&x,&y); if(map[x][y]==1) cout<<"No problem"<<endl; else if(map[x][y]==-1) { if(find(f[x])==find(f[y])) cout<<"OK but..."<<endl; else cout<<"No way"<<endl; } else cout<<"OK"<<endl; } return 0; }
相关 并查集 Ⅱ \[poj 1611\] ([http://poj.org/problem?id=1611][http_poj.org_problem_id_1611]) 题目描述: T 古城微笑少年丶/ 2022年08月03日 14:35/ 0 赞/ 291 阅读
相关 并查集运用 来点心得体会吧! intFind(int x) \{ return x==fa\[x\]?x:fa\[x\]=Find(fa\[x\]); \} vo 野性酷女/ 2022年06月17日 13:59/ 0 赞/ 121 阅读
相关 并查集 并查集JAVA版框架 并查集是一种用来管理元素分组情况的数据结构。 并查集可以高效地进行如下操作: \--查询元素a和元素b是否属于同一组 落日映苍穹つ/ 2022年06月16日 12:44/ 0 赞/ 329 阅读
相关 并查集 这个文章是几年前水acm的时候转的, 当时也不知道作者是谁, 要是有人知道的话说一下吧 并查集是我暑假从高手那里学到的一招,觉得真是太精妙的设计了。以前我无法解决的 港控/mmm°/ 2022年06月13日 14:13/ 0 赞/ 311 阅读
相关 并查集 > 题目 > 某学校近期要组织全校同学出去参加某项活动,由于人数众多,学校决定让同学们自行组队,以小组为单位进行活动。假设学校一共n个同学,每个同学有一个唯一的数字作为标签 Myth丶恋晨/ 2022年06月08日 09:24/ 0 赞/ 320 阅读
相关 并查集 森林: 森林是由若干棵互不相交的树组成,两棵树分别独立,没有交集 ![20181112082744488.png][] 并查集: 并查集的结构和森林十分相似,是 Love The Way You Lie/ 2022年04月17日 02:27/ 0 赞/ 379 阅读
相关 并查集 来看一个实例,[杭电1232畅通工程][1232] 首先在地图上给你若干个城镇,这些城镇都可以看作点,然后告诉你哪些对城镇之间是有道路直接相连的。最后要解决的是整幅图的连通性 我就是我/ 2022年03月29日 10:58/ 0 赞/ 384 阅读
相关 『并查集及其拓展运用』 -------------------- 并查集 并查集是一种可以动态地维护若干个不重叠的集合,并支持查询和合并的数据结构。 具体地说,并查集支持以下两种操作: > 妖狐艹你老母/ 2022年01月09日 22:19/ 0 赞/ 175 阅读
相关 并查集 一、算法解释 用于解决一些有N个元素的集合应用问题。 1、将每个元素初始化为自身单独成为一个集合。用p\[i\]的值表示该元素所在集合。 ![这里写图片描述][S 桃扇骨/ 2021年09月14日 02:56/ 0 赞/ 488 阅读
相关 并查集 并查集的作用就是快速判断两个元素是否在同一个集合中,快速将两个集合合并 基本模板 include <iostream> include <a 比眉伴天荒/ 2021年06月22日 15:37/ 0 赞/ 588 阅读
还没有评论,来说两句吧...