PKU OJ A Bug's life
http://bailian.openjudge.cn/tm2018/G/
#include <iostream>
#include <vector>
#include <string>
using namespace std;
const int N = 2001;
bool flag = false;
//父亲节点
int Father[N];
// 要想与根节点之间的关系如何表示?可以用0表示与根节点同性别,
//用1表示与根节点是不同性别,可以用%2,来判断两只虫子的性别
//是不是相同,对2取余可以保证,用r[N]来表示N节点与根节点的关系
int r[N];
int Find(int x)
{
if (x == Father[x]) return x;
int temp = Father[x];
//如果不是根节点,那么把父节点继续拿去找根节点,然后令x的父节点直接为根节点
//为路径压缩
Father[x] = Find(Father[x]);
//更新x与父节点的关系
r[x] = (r[x] + r[temp]) % 2;
return Father[x];
} void Union(int x, int y)
{
auto fx = Find(x);
auto fy = Find(y);
if (fx == fy)
{
//如果2个节点的根节点相同,且性别也相同,那么是homesexual
if (r[x] == r[y])
{
flag = true;
return;
}
}
else
{
//如果不同,把fx合到fy的树里去
Father[fx] = fy;
//且改变fx节点与父节点的状态
r[fx] = (r[x] + r[y] + 1) % 2;
}
} int main()
{
int scenario;
cin >> scenario;
int cnt = 1;
while (scenario-- > 0)
{
int n, m;
cin >> n >> m;
//每次场景将flag重新重置为false
flag = false;
for (int i = 1; i <= n; i++)
{
Father[i] = i;
r[i] = 0;
}
vector<std::pair<int, int>> v;
for (int i = 0; i < m; i++)
{
int tempa, tempb;
cin >> tempa >> tempb;
v.emplace_back(tempa, tempb);
}
for (int i = 0; i < m; i++)
{
Union(v[i].first, v[i].second);
}
if (flag)
{
std::cout << "Scenario #" + to_string(cnt) + ":" << std::endl;
std::cout << "Suspicious bugs found!" << std::endl;
std::cout << std::endl;
}
else
{
std::cout << "Scenario #" + to_string(cnt) + ":" << std::endl;
std::cout << "No suspicious bugs found!" << std::endl;
std::cout << std::endl;
}
cnt++;
}
return 0;
}
并查集 请看:
https://www.cnblogs.com/xzxl/p/7226557.html
题解请看:
https://www.luogu.org/problemnew/solution/SP3377
PKU OJ A Bug's life的更多相关文章
- PKU OJ 1002 487-3279
PKU OJ 1002 487-3279 487-3279 Description Businesses like to have memorable telephone numbers. One w ...
- pku oj overhang叠加卡片求最少的卡片数
这个估计是里面第二简单的了,因为第一简单的是求a+b 哈哈,一submit就ac了 题目如下: Description How far can you make a stack of cards ov ...
- PKU OJ Exponentiation
ExponentiationTime Limit: 500MS Memory Limit: 10000KTotal Submissions: 155886 ...
- [转]论acm与泡妞
abstract :本文从各个方面讨论了泡妞与做题之间的相似之处与不同点,尽量的站在一个公平的角度阐述这一问题,所得的研究成果填补了国内外的理论空白. - 泡了一个好妞就好像做了一道难题一样快感都是相 ...
- 练习SQL代码
---------PS:但凡有聚合函数(where),必然后Group by,Group by后面跟having ---------面试题 SELECT name,sum(fen) as s from ...
- acm.njupt 1001-1026 简单题
点击可展开上面目录 Acm.njupt 1001-1026简单题 第一页许多是简单题,每题拿出来说说,没有必要,也说不了什么. 直接贴上AC的代码.初学者一题题做,看看别人的AC代码,寻找自己的问题. ...
- 2016.10.6初中部上午NOIP普及组比赛总结
2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...
- 刘汝佳黑书 pku等oj题目
原文地址:刘汝佳黑书 pku等oj题目[转]作者:小博博Mr 一.动态规划参考资料:刘汝佳<算法艺术与信息学竞赛><算法导论> 推荐题目:http://acm.pku.edu. ...
- PKU 百练OJ Arbitrage
http://bailian.openjudge.cn/practice/2240/ #include <iostream> #include <string> #includ ...
随机推荐
- Mobox企业网盘回收站文件清空与恢复的管控
1. Mobox系统提供了 个人网盘的回收站 2. Mobox系统提供了 针对公司及部门文档柜的回收站 Mobox系统对个人网盘的回收站可以做这样的限制 1) 可以通过安装程序 ,不出现 回收站 2 ...
- The Counting Problem
The Counting Problem 询问区间\([a,b]\)中\(1\sim 9\)出现的次数,0 < a, b < 100000000. 解 显然为数位递推,考虑试填法,现在关键 ...
- 树形dp经典换根法——cf1187E
假设以u为根时结果是tot,现在转换到了以u的儿子v为根,那么结果变成了tot-size[v]+(sizetot-size[v]) 根据这个转移方程,先求出以1为根的tot,然后dfs一次转移即可 # ...
- Objective-C 中的 Meta-class 是什么?
在这篇文章中,我关注的是 Objective-C 中的一个陌生的概念-- meta-class.在 Objective-C 中的每个类都有一个相关联的 meta-class,但是你很少会直接使用 me ...
- WEB前端使用的CSS3选择器
首先说first-child与last-child,这两个选择器很容易明白,就是父元素下的第一个子元素和最后一个子元素.而nth-child和nth-last-child则是父元素下指定序号的子元素, ...
- a标签 href触发及传值
var d=document.getElementById("exportA");alert(d.href);d.href="${ctx}/templet/tEdasTe ...
- 第四周——重新clone项目后maven问题
重新clone项目后,一直报错,"类重复..." clean后install也无效果. 原因是idea在重启项目时会更改maven为默认的idea自带的maven配置,要重新设置
- 03_mybatis配置文件详解
1. SqlMapConfig.xml mybatis全局配置文件SqlMapConfig.xml,配置内容如下: *properties(属性) setting(全局配置参数) typeAliase ...
- vue-router使用入门
安装及基本配置 # 安装 npm install vue-router # 使用 import Vue from 'vue' import VueRouter from 'vue-router' Vu ...
- NOI 2001 食物链 /// 并查集 oj22035
Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1~N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到 ...