洛谷 P1551 亲戚
2024-08-31 17:56:03
题目背景
若某个家族人员过于庞大,要判断两个是否是亲戚,确实还很不容易,现在给出某个亲戚关系图,求任意给出的两个人是否具有亲戚关系。
题目描述
规定: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 ;
}
最新文章
- winfrom组件圆角
- 用centos光盘安装RPM包的方法
- ecshop /pick_out.php SQL Injection Vul By Local Variable Overriding
- 关于Thread.getContextClassLoader的使用场景问题
- JS模块化工具requirejs教程(一):初识requirejs
- Android的IPC机制(一)——AIDL的使用
- js生成随机数的方法实例总结
- 写一方法计算实现任意个整数之和.在主调函数中调用该函数,实现任意个数之和。(使用params参数)
- iOS 多语言 浅析
- Myeclipse8.5中svn插件安装方法总结
- window/mac系统关机
- java 之 建造者模式(大话设计模式)
- 19 Zabbix 利用Scripts栏目对Hosts远程执行命令
- Mat, IplImage, CvMat, Cvarr关系及元素获取
- 代码对齐--string|stream
- [Swift]LeetCode996. 正方形数组的数目 | Number of Squareful Arrays
- jquery表单提交的新写法
- Spring Security的核心拦截器
- C语言课堂题集
- 堆与堆排序/Heap&;Heap sort
热门文章
- Debian9 ifconfig命令找不到解决办法
- BZOJ3645: Maze(FFT多项式快速幂)
- lsblk---列出所有可用块设备的信息,
- 阿里&;163 yum源
- 【CS Round #37 (Div. 2 only) B】Group Split
- Mysql学习总结(11)——MySql存储过程与函数
- WPF和WinForm的区别, 数据驱动与事件驱动的优势对比
- Android底层驱动开发(一)
- HDU4596 Yet another end of the world 扩展欧几里德性质
- qwt的安装和移植-