洛谷 P1551 亲戚

题目背景

若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系。

题目描述

规定:x和y是亲戚,y和z是亲戚,那么x和z也是亲戚。如果x,y是亲戚,那么x的亲戚都是y的亲戚,y的亲戚也都是x的亲戚。

输入输出格式

输入格式:

第一行:三个整数n,m,p,(n<=5000,m<=5000,p<=5000),分别表示有n个人,m个亲戚关系,询问p对亲戚关系。

以下m行:每行两个数Mi,Mj,1<=Mi,Mj<=N,表示Mi和Mj具有亲戚关系。

接下来p行:每行两个数Pi,Pj,询问Pi和Pj是否具有亲戚关系。

输出格式:

P行,每行一个’Yes’或’No’。表示第i个询问的答案为“具有”或“不具有”亲戚关系。

输入输出样例

输入样例#1: 复制

6 5 3
1 2
1 5
3 4
5 2
1 3
1 4
2 3
5 6
输出样例#1: 复制

Yes
Yes
No 思路:简单的并查集入门题 难度:普及-
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int n, m, k;
int fa[];
int find(int x) {
if(fa[x] == x) return x;
else return fa[x] = find(fa[x]);
}
int main() {
scanf("%d%d%d", &n, &m, &k);
for(int i = ; i <= n; i++)
fa[i] = i;
for(int i = ; i <= m; i++) {
int a, b;
scanf("%d%d", &a, &b);
int x = find(a), y = find(b);
if(x == y) continue;
fa[y] = x;
}
for(int i=;i<=k;i++) {
int a,b;
scanf("%d%d",&a,&b);
if(find(a)==find(b)) printf("Yes\n");
else printf("No\n");
}
return ;
}

最新文章

  1. winfrom组件圆角
  2. 用centos光盘安装RPM包的方法
  3. ecshop /pick_out.php SQL Injection Vul By Local Variable Overriding
  4. 关于Thread.getContextClassLoader的使用场景问题
  5. JS模块化工具requirejs教程(一):初识requirejs
  6. Android的IPC机制(一)——AIDL的使用
  7. js生成随机数的方法实例总结
  8. 写一方法计算实现任意个整数之和.在主调函数中调用该函数,实现任意个数之和。(使用params参数)
  9. iOS 多语言 浅析
  10. Myeclipse8.5中svn插件安装方法总结
  11. window/mac系统关机
  12. java 之 建造者模式(大话设计模式)
  13. 19 Zabbix 利用Scripts栏目对Hosts远程执行命令
  14. Mat, IplImage, CvMat, Cvarr关系及元素获取
  15. 代码对齐--string|stream
  16. [Swift]LeetCode996. 正方形数组的数目 | Number of Squareful Arrays
  17. jquery表单提交的新写法
  18. Spring Security的核心拦截器
  19. C语言课堂题集
  20. 堆与堆排序/Heap&amp;Heap sort

热门文章

  1. Debian9 ifconfig命令找不到解决办法
  2. BZOJ3645: Maze(FFT多项式快速幂)
  3. lsblk---列出所有可用块设备的信息,
  4. 阿里&amp;163 yum源
  5. 【CS Round #37 (Div. 2 only) B】Group Split
  6. Mysql学习总结(11)——MySql存储过程与函数
  7. WPF和WinForm的区别, 数据驱动与事件驱动的优势对比
  8. Android底层驱动开发(一)
  9. HDU4596 Yet another end of the world 扩展欧几里德性质
  10. qwt的安装和移植-