P1551 亲戚

题目链接:落谷

题目链接:TFLS OJ

落谷题解(具体分析见慎入潜出P239)

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n,m,p;
  4. int fu[5010];
  5. int find(int x){//查询是否是同一个家族
  6. if(x==fu[x]) return x;
  7. return fu[x]=find(fu[x]);
  8. }
  9. void connect(int x,int y){
  10. int f1=find(x);
  11. int f2=find(y);
  12. if(f1!=f2)
  13. fu[f1]=f2;
  14. }
  15. int main(){
  16. cin>>n>>m>>p;
  17. for(int i=1;i<=n;i++)//初始化,每个人为一个家族
  18. fu[i]=i;
  19. for(int i=0;i<m;i++){
  20. int x,y;
  21. cin>>x>>y;
  22. connect(x,y);//连接俩氢气
  23. }
  24. for(int i=0;i<p;i++){
  25. int x,y;
  26. cin>>x>>y;
  27. if(find(x)==find(y))
  28. cout<<"Yes"<<endl;
  29. else
  30. cout<<"No"<<endl;
  31. }
  32. return 0;
  33. }

OJ题解

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. int n,m,p;
  4. int fu[10500000];
  5. int find(int x){//查询是否是同一个家族
  6. if(x==fu[x]) return x;
  7. return fu[x]=find(fu[x]);
  8. }
  9. void connect(int x,int y){
  10. int f1=find(x);//
  11. int f2=find(y);
  12. if(f1!=f2)
  13. fu[f1]=f2;
  14. }
  15. int main(){
  16. scanf("%d%d",&n,&m);//OJ里cin,cout会超时(
  17. for(int i=1;i<=n;i++)//初始化家族,每人为一个家族
  18. fu[i]=i;
  19. for(int i=0;i<m;i++){
  20. int x,y;
  21. scanf("%d%d",&x,&y);
  22. connect(x,y);//连接俩氢气
  23. }
  24. cin>>p;
  25. for(int i=0;i<p;i++){
  26. int x,y;
  27. scanf("%d%d",&x,&y);
  28. if(find(x)==find(y))
  29. printf("Yes\n");
  30. else
  31. printf("No\n");
  32. }
  33. return 0;
  34. }

P1551 亲戚 && #569. 【例4-7】亲戚(并查集)的更多相关文章

  1. P1551 亲戚 并查集

    P1551 亲戚 题目背景 若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系. 题目描述 规定:x和y是亲戚,y和z是亲戚,那么 ...

  2. 洛谷 P1551 亲戚(并查集模板)

    嗯... 题目链接:https://www.luogu.org/problemnew/show/P1551 思路: 很显然地我们会发现,这是一道并查集的模板题,并且是考察了并查集中的”并“和”查“的操 ...

  3. 并查集 --以cogs259为例

    题目链接:http://cogs.pro:8081/cogs/problem/problem.php?pid=pySmxSVgP [问题描述]     或许你并不知道,你的某个朋友是你的亲戚.他可能是 ...

  4. 并查集——以nuist OJ P1648炼丹术为例

    并查集 定义:并查集是一种树形的数据结构,用于处理一些不相交集合的合并及查询问题 主要构成: 并查集主要由一个整型数组pre[]和两个函数find().join()构成. 数组pre[]记录了每个点的 ...

  5. 洛谷P1551 亲戚 (并查集模板题)

    链接 https://www.luogu.org/problemnew/show/P1551 代码 #include<bits/stdc++.h> using namespace std; ...

  6. 1346:【例4-7】亲戚(relation)

    并查集的模板题: #include<iostream> #include<cstdio> using namespace std; ; int fa[maxn]; int fi ...

  7. 又见关系并查集 以POJ 1182 食物链为例

    简单的关系并查集一般非常easy依据给出的关系搞出一个有向的环,那么两者之间的关系就变成了两者之间的距离. 对于此题: 若u.v不在一个集合内,则显然此条语句会合法(暂且忽略后两条.下同). 那么将f ...

  8. 洛谷P1547 Out of Hay

    题目背景 奶牛爱干草 题目描述 Bessie 计划调查N (2 <= N <= 2,000)个农场的干草情况,它从1号农场出发.农场之间总共有M (1 <= M <= 10,0 ...

  9. 黑社会团伙(gangs)

    题目描述 众所周知,香港的黑社会组织猖獗,警方希望能摸清他们的内部构成情况,特派小生前往调查.经过长期的卧底,小生初步获得了一些资料:整个组织有 n 个人,任何两个认识的人不是朋友就是敌人. 而且满足 ...

  10. 【bzoj1370】[Baltic2003]Gang团伙 并查集

    题目描述 在某城市里住着n个人,任何两个认识的人不是朋友就是敌人,而且满足: 1. 我朋友的朋友是我的朋友: 2. 我敌人的敌人是我的朋友: 所有是朋友的人组成一个团伙.告诉你关于这n个人的m条信息, ...

随机推荐

  1. 【GiraKoo】Android系统版本代号一览

    Android系统版本代号一览 Version CodeName API 时间 13.0 Tiramisu 33 2022.08 12.0 Snow Cone 31,32 2021.10 11.0 R ...

  2. DP杂谈【持续更新中】

    什么是DP? 推荐看一下. 正文 滚动数组优化 在一些空间贼小,时间还好的 DP 题目里,会用到优化空间的小技♂巧--滚动数组优化. 滚动数组,顾名思义,一个会滚动的数组,主要是怎样个滚法呢?接下来我 ...

  3. L1-025 正整数A+B (15 分)

    1.题目描述: 题的目标很简单,就是求两个正整数A和B的和,其中A和B都在区间[1,1000].稍微有点麻烦的是,输入并不保证是两个正整数. 输入格式: 输入在一行给出A和B,其间以空格分开.问题是A ...

  4. Python从0到1丨了解图像形态学运算中腐蚀和膨胀

    摘要:这篇文章将详细讲解图像形态学知识,主要介绍图像腐蚀处理和膨胀处理. 本文分享自华为云社区<[Python从零到壹] 四十七.图像增强及运算篇之腐蚀和膨胀详解>,作者: eastmou ...

  5. 详解RocketMQ 顺序消费机制

    摘要:顺序消息是指对于一个指定的 Topic ,消息严格按照先进先出(FIFO)的原则进行消息发布和消费,即先发布的消息先消费,后发布的消息后消费. 本文分享自华为云社区<RocketMQ 顺序 ...

  6. 【LeetCode】Find Pivot Index #724 Rust Solution

    给定一个整数类型的数组 nums,请编写一个能够返回数组 "中心索引" 的方法.我们是这样定义数组 中心索引 的:数组中心索引的左侧所有元素相加的和等于右侧所有元素相加的和.如果数 ...

  7. 300行代码模拟cdn

    这一生听过许多道理,但还是过不好这一生,这是因为缺少真正的动手实践,光听道理,缺少动手实践的过程,学习难免会让人觉得味同嚼蜡,所以我的分享都比较倾向于实践,在一次次动手实践的过程中感受知识原本纯真的模 ...

  8. Java 字符串反转,举例:键盘录入”abc”输出结果:”cba”

    代码如下: public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out. ...

  9. LocalTime转String类型,如下图

  10. SpringIoc容器之Aware

    1 前言 Aware是Spring提供的一个标记超接口,指示bean有资格通过回调样式的方法由Spring容器通知特定的框架对象,以获取到容器中特有对象的实例的方法之一.实际的方法签名由各个子接口确定 ...