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. Mobox企业网盘回收站文件清空与恢复的管控

    1. Mobox系统提供了 个人网盘的回收站 2. Mobox系统提供了 针对公司及部门文档柜的回收站 Mobox系统对个人网盘的回收站可以做这样的限制 1)  可以通过安装程序 ,不出现 回收站 2 ...

  2. The Counting Problem

    The Counting Problem 询问区间\([a,b]\)中\(1\sim 9\)出现的次数,0 < a, b < 100000000. 解 显然为数位递推,考虑试填法,现在关键 ...

  3. 树形dp经典换根法——cf1187E

    假设以u为根时结果是tot,现在转换到了以u的儿子v为根,那么结果变成了tot-size[v]+(sizetot-size[v]) 根据这个转移方程,先求出以1为根的tot,然后dfs一次转移即可 # ...

  4. Objective-C 中的 Meta-class 是什么?

    在这篇文章中,我关注的是 Objective-C 中的一个陌生的概念-- meta-class.在 Objective-C 中的每个类都有一个相关联的 meta-class,但是你很少会直接使用 me ...

  5. WEB前端使用的CSS3选择器

    首先说first-child与last-child,这两个选择器很容易明白,就是父元素下的第一个子元素和最后一个子元素.而nth-child和nth-last-child则是父元素下指定序号的子元素, ...

  6. a标签 href触发及传值

    var d=document.getElementById("exportA");alert(d.href);d.href="${ctx}/templet/tEdasTe ...

  7. 第四周——重新clone项目后maven问题

    重新clone项目后,一直报错,"类重复..." clean后install也无效果. 原因是idea在重启项目时会更改maven为默认的idea自带的maven配置,要重新设置

  8. 03_mybatis配置文件详解

    1. SqlMapConfig.xml mybatis全局配置文件SqlMapConfig.xml,配置内容如下: *properties(属性) setting(全局配置参数) typeAliase ...

  9. vue-router使用入门

    安装及基本配置 # 安装 npm install vue-router # 使用 import Vue from 'vue' import VueRouter from 'vue-router' Vu ...

  10. NOI 2001 食物链 /// 并查集 oj22035

    Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形.A吃B, B吃C,C吃A. 现有N个动物,以1~N编号.每个动物都是A,B,C中的一种,但是我们并不知道它到 ...