文章目录

  • 题目分析
  • 题目链接

题目分析



来源:acwing
分析:并查集的合并和查询。

  1. 问:一张照片上的鸟如何合并?相邻的合并(笔者采用的方式)或者全合并到第一只鸟就行,遍历一遍。所有照片中的鸟,合并的次数累加到变量cnt中。
  2. 问:如何统计鸟的数量?用一个bool数组,出现过的置为true。遍历一遍统计true的个数就是所有的鸟的数量total
  3. 问:如何统计树的数量?首先说一点,total是鸟的数量,初始化的时候每只鸟是一个独立的集合。树的数量是total - cnt。为什么是这个公式?这个道理就相当于,有3个集合,合并2个,还剩几个集合?当然还剩1个啦。
树的数量 = 鸟的数量 - 合并的次数
比如 照片1:1 2 3  照片2: 2 4 5 照片3:7 8 9
这个例子中,树的数量是2棵,是怎么求的?
过程如下:
总共鸟数total =8, 3张照片总共合并次数cnt=2+2+2 =6,
得出,树的数量= total -cnt =2。

ac代码

#include<bits/stdc++.h>
using namespace std;const int N = 1e4+10;
unordered_set<int> S[N];int n;
int p[N];
int birds[11]; //每张照片的鸟先存下来
bool st[N];
int find(int x){if(p[x] != x) p[x] = find(p[x]);return p[x];
}int main(){cin >> n;//初始化所有的鸟,每只鸟都是一个集合for(int i =1; i<N; i++) p[i] = i;//统计合并了多少次cntint cnt = 0;for(int i = 1; i<= n; i ++){int k;cin >>k;for(int j =0; j<k; j++) {cin >> birds[j];st[birds[j]] =true; //表示这只鸟存在一个集合中}//合并一张照片中的鸟//相邻的合并:前面的合并到后面的//从前往后枚举一遍,就合并完成为1个集合for(int j = 1; j<k; j++){int a = birds[j-1],b=birds[j];a = find(a),b = find(b);if(a != b){p[a] =b;cnt ++; } }}//统计所有的鸟的只数int total = 0;for(int i = 0; i<N;i ++) total += st[i];//树的数量 = 鸟的数量 - 合并的次数//比如 照片1:1 2 3  照片2: 2 4 5 照片3:7 8 9这个例子:树的数量:2棵//怎么求的? 总共鸟数total =8, 3张照片总共合并次数cnt=2+2+2 =6,树的数量= total -cnt =2cout<< total -cnt <<" "<<total<<endl;int q;cin >> q;while(q--){int a, b;cin >> a >> b;if(find(a) == find(b)) cout<<"Yes"<<endl;else cout<<"No"<<endl;}
}

题目链接

PAT甲级1118 Birds in Forest
https://www.acwing.com/problem/content/1610/

PAT甲级1118 Birds in Forest :[C++题解]并查集相关推荐

  1. PAT A 1118. Birds in Forest (25)【并查集】

    并查集合并 #include<iostream> using namespace std; const int MAX = 10010; int father[MAX],root[MAX] ...

  2. PAT题解-1118. Birds in Forest (25)-(并查集模板题)

    如题... #include <iostream> #include <cstdio> #include <algorithm> #include <stri ...

  3. 【题解】1118 Birds in Forest (25分)⭐⭐ 【并查集】

    [题解]1118 Birds in Forest (25分)⭐⭐ [并查集] 题解: 简单并查集,并一下查一下就好了,没学的同学抓紧学一下 经验小结: #include<bits/stdc++. ...

  4. PAT甲级1138 Postorder Traversal:[C++题解]前序遍历和中序遍历建树

    文章目录 题目分析 题目链接 题目分析 做过前面几道题,发现这道题就是一道模板题,递归建树即可. 还是使用笔者熟悉的hash表来找根,进行优化. 请移步至笔者的另一篇文章:PAT甲级1020 Tree ...

  5. PAT甲级1051 Pop Sequence:[C++题解]模拟栈、判断序列是否是合法的出栈序列

    文章目录 题目分析 题目来源 题目分析 来源:acwing 分析: 题意:将1~N压栈,判断给定序列是否是合法的出栈序列. 对于序列1~N中的每个值i,先将其压入栈.然后对于它就有两种处理方法:要么压 ...

  6. PAT甲级1085 Perfect Sequence :[C++题解]双指针

    文章目录 题目分析 题目来源 题目分析 来源:acwing 分析:求满足条件M≤m×pM \leq m\times pM≤m×p的区间[m, M]最长是多少.此处有一性质:当最大值M变大的时候,最小值 ...

  7. PAT甲级1046 Shortest Distance:[C++题解]前缀和

    文章目录 题目分析 题目链接 题目分析 来源:acwing 分析: 用前缀和快速求出一段的和.注意求两段,取最小值. ac代码 #include<bits/stdc++.h> using ...

  8. PAT甲级1037 Magic Coupon:[C++题解]贪心

    文章目录 题目分析 题目来源 题目分析 来源:acwing 分析: 贪心. 两个数列分别从大到小排列.从前往后遍历,如果a数组和b数组前k个数都是正数,就相乘累加到res中: 从后往前遍历,如果a数组 ...

  9. PAT甲级1140 Look-and-say Sequence:[C++题解]统计连续个数

    文章目录 题目分析 题目链接 题目分析 来源:acwing 规律是:对于前一项的每个值,输出当前值(该值必须连续)和它的个数. 比如: D下一项是D1,表示D有1个 D1下一项是D111,表示当前值D ...

最新文章

  1. Keepalived+LVS+Nginx+DRBD+Heartbeat+Zabbix集群架构
  2. 今天你快乐吗?AI 从走路姿态就能识别你的情绪
  3. git使用:本地分支merge到远程分支
  4. 如何用九条命令在一分钟内检查 Linux 服务器性能?
  5. 从 保龄球得分计算方法 浅析 深度学习
  6. 是否同一棵二叉搜索树
  7. sequelize 增加数据库字段_sequelize 5.0中文文档连接数据源及数据类型 (一) - node.js语言最好用的orm...
  8. Extract Any Audio Pro for Mac - mp3格式转换器
  9. matlab如何创建callback函数_MATLAB作图实例:46:显示复杂的三维对象
  10. 计算机辅助设计autocad2005(建筑)四级考试,计算机辅助设计(AutoCAD平台)
  11. MS17010原生打法
  12. 容错性设计原则(一)
  13. Siri 和谷歌竟然暗藏《复联4》彩蛋!
  14. Win11声卡驱动怎么更新?Win11声卡驱动更新方法
  15. STM32 内部flash 数据掉电存储
  16. Shiro 之 Subject 类
  17. 【自省篇】软件开发七宗罪
  18. BC61 金字塔图案
  19. JavaScript 中的事件类型3(读书笔记思维导图)
  20. 工程建筑职业院校学校大专学校院校类网站源码织梦模板 (带手机版数据同步)

热门文章

  1. 使用Maven Assembly plugin将依赖打包进jar
  2. Cocos2d-x 3.x plist+png 做动画
  3. Android百度地图定位
  4. JavaScript脚本放在哪里
  5. windows下用QTwebkit解析html
  6. Ubuntu 安装LAMP ...
  7. C#的多线程(2)——机制探索
  8. 用神经网络学习Fe原子光谱并反向求导计算权重
  9. ebp 函数堆栈esp_对于ESP、EBP寄存器的理解
  10. vs调试按钮为灰色的_IntelliJ IDEA 调试 Java 8,实在太香了