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

  1. 并查集——poj1611(入门)

    传送门:The Suspects 并查集水题 #include <iostream> #include <cstdio> #include <algorithm> ...

  2. 【转】并查集&MST题集

    转自:http://blog.csdn.net/shahdza/article/details/7779230 [HDU]1213 How Many Tables 基础并查集★1272 小希的迷宫 基 ...

  3. poj2492 A Bug's Life(带权并查集)

    题目链接 http://poj.org/problem?id=2492 题意 虫子有两种性别,有n只虫子,编号1~n,输入m组数据,每组数据包含a.b两只虫子,表示a.b为不同性别的虫子,根据输入的m ...

  4. poj1611 The Suspects(并查集)

    题目链接 http://poj.org/problem?id=1611 题意 有n个学生,编号0~n-1,m个社团,每个社团有k个学生,如果社团里有1个学生是SARS的疑似患者,则该社团所有人都要被隔 ...

  5. poj2492(种类并查集/各种解法)

    题目链接: http://poj.org/problem?id=2492 题意: 有t组测试数据, 对于每组数据,第一行n, m分别表示昆虫的数目和接下来m行x, y, x, y表示教授判断x, y为 ...

  6. poj1611(并查集)

    题目链接:http://poj.org/problem?id=1611 题意: SARS(非典型肺炎)传播得非常厉害,其中最有效的办法是隔离那些患病.和患病者接触的人.现在有几个学习小组,每小组有几个 ...

  7. poj1611 并查集 (路径不压缩)

    http://poj.org/problem?id=1611 题目大意: 有一个学校,有N个学生,编号为0-N-1,现在0号学生感染了非典,凡是和0在一个社团的人就会感染,并且这些人如果还参加了别的社 ...

  8. poj2492 带权并查集

    题意:研究一种生物,有n个生物个体,发现有一些之间进行了交配,给出了这些关系,问是否有同性恋的bug出现. 用0\1表示某元素和其祖先元素的性别关系,0 为相同,1 为不同,用 mod2 实现累计处理 ...

  9. poj1611 带权并查集

    题意:病毒蔓延,现在有 n 个人,其中 0 号被认为可能感染,然后给出多个社交圈,如果某个社交圈里有人被认为可能被感染,那么所有这个社交圈里的人都被认为可能被感染,现在问有多少人可能被感染. 带权并查 ...

随机推荐

  1. Sublime Text 3插件之SublimeTmpl:新建文件的模版插件

    SublimeTmpl能新建html.css.javascript.php.python.ruby六种类型的文件模板,所有的文件模板都在插件目录的templates文件夹里,可以自定义编辑文件模板. ...

  2. 7.MVC框架开发(创建层级项目)

    在一个项目比较大的时候,就会有多个层级项目 1)在项目中选定项目右建新建区域(新的层级项目),项目->右键->添加->区域,构成了一套独立的MVC的目录,这个目录包括Views,Co ...

  3. JS获取IP、MAC和主机名的几种方法

    方法一(只针对IE且客户端的IE允许AcitiveX运行,通过平台:XP,SERVER03,2000): 获取客户端IP. <HTML> <HEAD> <TITLE> ...

  4. HDU 4540 威威猫系列故事——打地鼠(DP)

    点我看题目 题意 :中文题,不详述. 思路 : 状态转移方程 dp[ i ][ j ] = dp[i-1][k] + fabs(a[ i ][ j ]-a[i-1][k]) ; dp[i][j]代表的 ...

  5. C语言关键字 - 铁布衫:const 转载

    const 描述:相传C世界中出现了一件极品装备const,它能的出现,让天下所有的刺客,黑客都失业了,在它的保护下,所有的变量都可以完好无损. 作用:const是constant的简写,表示海枯石栏 ...

  6. 各种HTTP错误消息含义

    错误代码 错误消息 400 无法解析此请求. 401.1 未经授权:访问由于凭据无效被拒绝. 401.2 未经授权: 访问由于服务器配置倾向使用替代身份验证方法而被拒绝. 401.3 未经授权:访问由 ...

  7. Android 自定义对话框(Dialog)位置,大小

    代码: package angel.devil; import android.app.Activity; import android.app.Dialog; import android.os.B ...

  8. C++类中静态变量和静态方法使用介绍!

    原链接:http://www.ecoviews.cn/net/archives/216.html 静态成员的提出是为了解决数据共享的问题.实现共享有许多方法,如:设置全局性的变量或对象是一种方法.但是 ...

  9. Android-相册效果(图片缩放 自由滑动)

    先上图: 很多时候 我们会有这么一个需求: 展示一组图片 每个Item的图片 可以自由拉伸 滑动 焦点不冲突 网上有很多实现方法 通过自定义Gallery和ImageView来实现 个人不是很推荐 在 ...

  10. 学习笔记-[Maven实战]-第三章:Maven使用入门(2)

    使用maven执行编译和测试 1.maven执行编译 (1).在pom.xml上点右键,选择Maven build... (2).在Goals里输入clean complie,执行编译 执行结果: [ ...