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的更多相关文章

  1. PKU OJ 1002 487-3279

    PKU OJ 1002 487-3279 487-3279 Description Businesses like to have memorable telephone numbers. One w ...

  2. pku oj overhang叠加卡片求最少的卡片数

    这个估计是里面第二简单的了,因为第一简单的是求a+b 哈哈,一submit就ac了 题目如下: Description How far can you make a stack of cards ov ...

  3. PKU OJ Exponentiation

    ExponentiationTime Limit: 500MS                      Memory Limit: 10000KTotal Submissions: 155886   ...

  4. [转]论acm与泡妞

    abstract :本文从各个方面讨论了泡妞与做题之间的相似之处与不同点,尽量的站在一个公平的角度阐述这一问题,所得的研究成果填补了国内外的理论空白. - 泡了一个好妞就好像做了一道难题一样快感都是相 ...

  5. 练习SQL代码

    ---------PS:但凡有聚合函数(where),必然后Group by,Group by后面跟having ---------面试题 SELECT name,sum(fen) as s from ...

  6. acm.njupt 1001-1026 简单题

    点击可展开上面目录 Acm.njupt 1001-1026简单题 第一页许多是简单题,每题拿出来说说,没有必要,也说不了什么. 直接贴上AC的代码.初学者一题题做,看看别人的AC代码,寻找自己的问题. ...

  7. 2016.10.6初中部上午NOIP普及组比赛总结

    2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...

  8. 刘汝佳黑书 pku等oj题目

    原文地址:刘汝佳黑书 pku等oj题目[转]作者:小博博Mr 一.动态规划参考资料:刘汝佳<算法艺术与信息学竞赛><算法导论> 推荐题目:http://acm.pku.edu. ...

  9. PKU 百练OJ Arbitrage

    http://bailian.openjudge.cn/practice/2240/ #include <iostream> #include <string> #includ ...

随机推荐

  1. hibernate的核心思想

    Hibernate的核心思想是ROM对象关系映射机制.它是将表与表之间的操作映射成对象与对象之间的操作.也就是从数据库中提取的信息会自动按照你设置的映射要求封装成特定的对象.所以hibernate就是 ...

  2. C++ 系列:交换两个数字

    1. 创建中间变量 这是最快也是最简单的办法,例如: #include<stdio.h> int main(){ int a=10; int b=20; int temp; printf( ...

  3. scala中Tuple简单使用

    /** * Tuple简单使用记录 * 最大22个参数 */ object TupleUse { def main(args: Array[String]): Unit = { // 简单Tuple ...

  4. Windows 开启win32 控制台

    {     AllocConsole();     FILE *Journal = NULL;     freopen_s(&Journal, "CONOUT$", &qu ...

  5. Windows copy

    将一份或多份文件复制到另一个位置. COPY [/D] [/V] [/N] [/Y | /-Y] [/Z] [/L] [/A | /B ] source [/A | /B]     [+ source ...

  6. C++ BASS 实例

    #include <iostream> #include <string> #include <map> #include "..\sdk\bass\in ...

  7. DOM——获取页面元素

    获取页面元素 为什么要获取页面元素 例如:我们想要操作页面上的某部分(显示/隐藏,动画),需要先获取到该部分对应的元素,才进行后续操作 根据id获取元素 var div = document.getE ...

  8. MFC int转CString

    方法一. int iVar = 7489; char szBuf[100]; _itoa(iVar, szBuf, 10); CString ss(szBuf); SetDlgItemText(IDC ...

  9. C++访问sqlite3的初体验

    Sqlite确实是一个比较好的本地数据库,从接触它的时候就喜欢上了它,它可以在很多情况下简化应用.不过以前都是在Java里面使用,或者Linux C下使用的,现在有个项目(C++)可能我会用到sqli ...

  10. mui 上拉加载 实现分页加载功能

    mui 上拉加载 实现分页加载功能,效果图: 分页功能(上拉加载): 1.引入需要的css.js文件 <link href="static/css/mui.css" rel= ...