并查集 poj1611&poj2492
poj1611 简单题
代码中id记录父节点,sz记录子树规模。一个集合为一棵树。
#include <iostream>
#include <cstdio>
using namespace std; int id[300005];
int sz[300005]; void add(int a, int b)
{
int i, j;
for (i = a; i != id[i]; i = id[i]);
for (j = b; j != id[b]; j = id[j]);
if (i == j) return;
if (sz[i] < sz[j]) {
id[i] = j;
sz[j] += sz[i];
} else {
id[j] = i;
sz[i] += sz[j];
}
} int main()
{
int n, m, cnt, root, temp;
while (scanf("%d%d", &n, &m) != EOF) {
if (!n) break;
for (int i = 0; i < n; ++i) {
id[i] = i;
sz[i] = 1;
}
for (int i = 0; i < m; ++i) {
scanf("%d", &cnt);
scanf("%d", &root);
for (int j = 1; j < cnt; ++j) {
scanf("%d", &temp);
add(root, temp);
}
}
int ans = 0;
int rt;
for (rt = 0; rt != id[rt]; rt = id[rt]);
for (int i = 0; i < n; ++i) {
int j;
for (j = i; j != id[j]; j = id[j]);
if (j == rt) ++ans;
}
printf("%d\n", ans);
}
return 0;
}
poj 2492
题目也是醉了,看半天没看懂= =#
输入每对a b表示a和b是夫妻,问有没有同性恋= =
把每一次a b放入同一集合,并用rel记录每个节点和它父节点的相对关系。这样同一集合的任意两点间关系就确定了
/**********************************************
Memory: 8500 KB Time: 125 MS
Language: G++ Result: Accepted
***********************************************/
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std; int id[2010], sz[2010];
int a[1000005], b[1000005];
int rel[2010]; //和父节点的性别是否一致,一致为0,否则为1 int Scan() { //输入外挂
int res = 0, flag = 0;
char ch;
if((ch = getchar()) == '-') flag = 1;
else if(ch >= '0' && ch <= '9') res = ch - '0';
while((ch = getchar()) >= '0' && ch <= '9')
res = res * 10 + (ch - '0');
return flag ? -res : res;
} void add(int a, int b)
{
int i, j;
int rel_a = 0, rel_b = 0;
for (i = a; i != id[i]; i = id[i])
rel_a = (rel_a + rel[i]) % 2; //a和根节点的关系
for (j = b; j != id[j]; j = id[j])
rel_b = (rel_b + rel[j]) % 2; //b和根节点的关系
if (i == j) return ;
if (sz[i] <= sz[j]) { //i->j
sz[j] += sz[i];
id[i] = j;
rel[i] = (rel_a == rel_b) ? 1 : 0; } else { //j->i
sz[i] += sz[j];
id[j] = i;
rel[j] = (rel_a == rel_b) ? 1 : 0;
}
} int is_gay(int a, int b)
{
int i, j;
int rel_a = 0, rel_b = 0;
for (i = a; i != id[i]; i = id[i])
rel_a = (rel_a + rel[i]) % 2;
for (j = b; j != id[j]; j = id[j])
rel_b = (rel_b + rel[j]) % 2;
if (i == j && rel_a == rel_b)
return 1;
return 0;
} int main()
{
int t, m, n;
t = Scan();
for (int k = 1; k <= t; ++k) {
n = Scan();
m = Scan();
for (int i = 1; i <= n; ++i) {
id[i] = i;
sz[i] = 1;
rel[i] = 0;
}
for (int i = 0; i < m; ++i) {
a[i] = Scan();
b[i] = Scan();
add(a[i], b[i]);
}
int i;
for (i = 0; i < m; ++i) {
if (is_gay(a[i], b[i]))
break;
}
printf("Scenario #%d:\n%s\n\n", k, i == m ? "No suspicious bugs found!" : "Suspicious bugs found!");
}
return 0;
}
总结经验教训:以后多敲两行也不能复制粘贴= =太坑。。。
并查集 poj1611&poj2492的更多相关文章
- 并查集——poj1611(入门)
传送门:The Suspects 并查集水题 #include <iostream> #include <cstdio> #include <algorithm> ...
- 【转】并查集&MST题集
转自:http://blog.csdn.net/shahdza/article/details/7779230 [HDU]1213 How Many Tables 基础并查集★1272 小希的迷宫 基 ...
- poj2492 A Bug's Life(带权并查集)
题目链接 http://poj.org/problem?id=2492 题意 虫子有两种性别,有n只虫子,编号1~n,输入m组数据,每组数据包含a.b两只虫子,表示a.b为不同性别的虫子,根据输入的m ...
- poj1611 The Suspects(并查集)
题目链接 http://poj.org/problem?id=1611 题意 有n个学生,编号0~n-1,m个社团,每个社团有k个学生,如果社团里有1个学生是SARS的疑似患者,则该社团所有人都要被隔 ...
- poj2492(种类并查集/各种解法)
题目链接: http://poj.org/problem?id=2492 题意: 有t组测试数据, 对于每组数据,第一行n, m分别表示昆虫的数目和接下来m行x, y, x, y表示教授判断x, y为 ...
- poj1611(并查集)
题目链接:http://poj.org/problem?id=1611 题意: SARS(非典型肺炎)传播得非常厉害,其中最有效的办法是隔离那些患病.和患病者接触的人.现在有几个学习小组,每小组有几个 ...
- poj1611 并查集 (路径不压缩)
http://poj.org/problem?id=1611 题目大意: 有一个学校,有N个学生,编号为0-N-1,现在0号学生感染了非典,凡是和0在一个社团的人就会感染,并且这些人如果还参加了别的社 ...
- poj2492 带权并查集
题意:研究一种生物,有n个生物个体,发现有一些之间进行了交配,给出了这些关系,问是否有同性恋的bug出现. 用0\1表示某元素和其祖先元素的性别关系,0 为相同,1 为不同,用 mod2 实现累计处理 ...
- poj1611 带权并查集
题意:病毒蔓延,现在有 n 个人,其中 0 号被认为可能感染,然后给出多个社交圈,如果某个社交圈里有人被认为可能被感染,那么所有这个社交圈里的人都被认为可能被感染,现在问有多少人可能被感染. 带权并查 ...
随机推荐
- 与wait for a undo record相关的系统卡死
今天下班之前同事过来找我寻求帮助,说是某客户的ORACEL数据库服务器从昨天起就开始很奇怪,一个语句执行很慢很慢,好像整个系统都卡住了. 问题1:请问最近应用系统有更新过程序吗?答:没有更新 ...
- java学习:用反射构造bean
先贴一些反射的基本知识:-------------------------------------------------------------------- 一.什么是反射:反射的概念是由Smit ...
- Android Learning:微信第三方登录
这两天,解决了微信第三方授权登录的问题,作为一个新手,想想也是一把辛酸泪.我想着,就把我的遇到的坑给大家分享一下,避免新手遇到我这样的问题能够顺利避开. 步骤一 微信开发者平台 我开始的解决思路是,去 ...
- Windows 2008 故障转移群集介绍
转载:http://dufei.blog.51cto.com/382644/902026 今天有客户问起Windows 群集的相关内容,毕竟Windows Server2008所支持的群集技术和Win ...
- [转载]初学C#之list
C# List<T>用法 所属命名空间:System.Collections.Generic public class List<T> : IList<T>, IC ...
- 开发安全的Web程序
目录0x1:什么是安全的Web应用程序0x2:过滤输入的数据0x3:转义输出的数据0x4:Register Globals0x5:magic_quotes_gpc0x6:错误信息的报告0x7:文件的安 ...
- Chapter 17. Objects and Inheritance(对象与继承)
javascript面向对象编程有几个层面: 1: 单一对象 (covered in Layer 1: Single Objects) 2: 对象之间的 prototype (described i ...
- 对C语言中sizeof细节的三点分析
转自对C语言中sizeof细节的三点分析 1.sizeof是运算符,跟加减乘除的性质其实是一样的,在编译的时候进行执行,而不是在运行时才执行. 那么如果编程中验证这一点呢?ps:这是前两天朋友淘宝面试 ...
- 找不到mysql服务或mysql服务名无效
问题原因:mysql服务没有安装. 解决办法: 在 mysql bin目录下 以管理员的权限 执行 mysqld -install命令 出现:Service successfully installe ...
- 《linux程序设计》笔记 第一章 入门
linux程序存放位置linux主要有一下几个存放程序的目录: /bin 系统启动程序目录 /usr/bin 用户使用的标准程序 /usr/local/bin 用于存放软件安装目录 /usr ...