并查集 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 号被认为可能感染,然后给出多个社交圈,如果某个社交圈里有人被认为可能被感染,那么所有这个社交圈里的人都被认为可能被感染,现在问有多少人可能被感染. 带权并查 ...
随机推荐
- 微信web开发者工具调试
微信web开发者工具调试 前几天写了一篇使用fiddler调试微信端页面的,然后博友评论说使用fiddler太麻烦了,推荐使用微信web开发者工具调试微信页面,这两天弄着玩了一下,很强大.这篇文章只是 ...
- Android XML文件解析
在Android平台上可以使用Simple API for XML(SAX) . Document Object Model(DOM)和Android附带的pull解析器解析XML文件. 下面是本例子 ...
- 求解 s = (1*1)!+(2*2)! + (3*3)!+...+(n*n)! (C语言)
提示:定义函数可以求阶乘,再定义函数求阶乘之和.1和0的阶乘是1,n(n > 1)的阶乘是n * (n-1) * (n - 2) * … * 1 //采用了函数嵌套调用和函数递归调用 //求解阶 ...
- 在C#中关于excel的导入和导出操作
一.先来看看最常见的导入操作吧! private void Import() { //打开excel选择框 OpenFileDialog frm = new OpenFileDialog(); frm ...
- 南方数据企业0day
漏洞影响版本 v10.0 v11.0 关键字:inurl:”HomeMarket.asp” 默认后台:/admin 直接爆用户密码: http://www.xxx.com/NewsType.asp?S ...
- 1008: [HNOI2008]越狱
n个人,m种信仰: 问你相邻的人信仰不同的情况有多少种? 首先第一个人有m种选择,第二个人有m-1种选择,后面所有的人都只有m-1种选择: 所以结果就是m^n-m*(m-1)^(n-1) #inclu ...
- DataTable转换List<T>集合的方法
using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Data; ...
- POJ 3352 Road Construction (边双连通分量)
题目链接 题意 :有一个景点要修路,但是有些景点只有一条路可达,若是修路的话则有些景点就到不了,所以要临时搭一些路,以保证无论哪条路在修都能让游客到达任何一个景点 思路 :把景点看成点,路看成边,看要 ...
- easyui源码翻译1.32--Calendar(日历)
前言 前几天加班比较忙 未能及时更新翻译的 今天多发布几篇..下载该插件翻译源码 日历控件显示一个月的日历,允许用户选择日期和移动到下一个或上一个月.默认情况下,一周的第一天是周日.它可以通过设置'f ...
- VIM 及其插件使用快捷键汇总
我的博客:www.while0.com vim搜索取消高亮 :nohl