POJ1703Find them, Catch them
| Time Limit: 1000MS | Memory Limit: 10000K | |
| Total Submissions: 37722 | Accepted: 11632 |
Description
Assume N (N <= 10^5) criminals are currently in Tadu City, numbered from 1 to N. And of course, at least one of them belongs to Gang Dragon, and the same for Gang Snake. You will be given M (M <= 10^5) messages in sequence, which are in the following two kinds:
1. D [a] [b]
where [a] and [b] are the numbers of two criminals, and they belong to different gangs.
2. A [a] [b]
where [a] and [b] are the numbers of two criminals. This requires you to decide whether a and b belong to a same gang.
Input
Output
Sample Input
1
5 5
A 1 2
D 1 2
A 1 2
D 2 4
A 1 4
Sample Output
Not sure yet.
In different gangs.
In the same gang. 又把种类并查集复习了一遍发现以前写的好乱。
做这种题就是要设一种关系用来表示它与父节点的关系,用a[x]来表示x与x父节点的关系,a[x] == 0表示x与父节点同类,否则异类
那么x的父节点与x的关系是跟x与他父节点的关系是一样的,这点比食物链那题简单
而求子节点与爷爷节点关系公式 (a[father[x] + a[x] ) % 2;通过枚举可以得到。因此在find_fahter更改关系时提供了凭据
#include <iostream>
#include <cstring>
#include <algorithm>
#include <cstdio>
using namespace std;
const int MAX = + ;
int father[MAX],a[MAX];
int find_father(int x)
{
if(x == father[x])
return x;
int t = find_father(father[x]);
a[x] = (a[father[x]] + a[x]) % ;
return father[x] = t;
}
void Union(int x,int y)
{
int fx = find_father(x);
int fy = find_father(y);
father[fx] = fy;
if(a[y] == ) //x和y是不同帮派, 如果y和fy是相同的帮派,{如果x和fx是同一帮派的话,fx就与fy不同,a[fx] = 1 - 0;如果x和fx不是同一帮派 fx和fy相同,a[fx] = 1 - 1;如果y和fy是不同的帮派即a[y] == 1,那么x和fy肯定是一派的,
{
a[fx] = - a[x];
}
else
{
a[fx] = a[x];
}
}
int main()
{
int t,n,m;
scanf("%d", &t);
while(t--)
{
scanf("%d%d", &n,&m);
for(int i = ; i <= n; i++)
{
father[i] = i;
a[i] = ;
}
char ch;
int x,y;
getchar();
while(m--)
{
scanf("%c%d%d", &ch,&x,&y);
getchar();
if(ch == 'A')
{
int fx = find_father(x);
int fy = find_father(y);
if(fx != fy)
{
printf("Not sure yet.\n");
}
else
{
if(a[x] == a[y])
{
printf("In the same gang.\n");
}
else
printf("In different gangs.\n");
} }
else if(ch == 'D')
{
Union(x,y);
}
}
} return ;
}
之前结构体做的比较麻烦,原理一样的
#include <iostream>
#include <cstring>
#include <cstdio>
#include <algorithm>
using namespace std;
const int MAX = +;
struct person
{
int num;
int bang;
int father;
};
person per[MAX];
int find_father(person &node)
{
if(node.father == node.num)
return node.father;
int temp = node.father; //这个很重要,因为是通过当前数与父节点关系,父节点与总父节点的关系来判断当前数与总父节点的关系,
node.father = find_father(per[temp]);
node.bang = (node.bang + per[temp) % ; //本来这里写的是(node.bang + per[node.father))%2; 因为经过上一步递归更新父节点,此时的node.father已经是总父节点了,so...
return node.father;
}
int main()
{
int t;
scanf("%d", &t);
while(t--)
{
int n,m,a,b,fa,fb;
char c;
scanf("%d%d", &n,&m);
getchar();
for(int i = ; i <= n; i++)
{
per[i].num = i;
per[i].father = i;
per[i].bang = ;
}
while(m--)
{
scanf("%c%d%d", &c,&a,&b);
getchar(); if(c == 'D')
{
fa = find_father(per[a]);
fb = find_father(per[b]);
if(fa != fb) {
per[fb].father = fa;
if(per[a].bang== ) //这里要举例找规律
per[fb].bang = - per[b].bang;
else
per[fb].bang = per[b].bang;
}
}
else if(c == 'A')
{
fa = find_father(per[a]);
fb = find_father(per[b]);
if(fa != fb)
printf("Not sure yet.\n");
else
{
if(per[a].bang == per[b].bang)
printf("In the same gang.\n");
else
printf("In different gangs.\n");
}
} }
}
return ;
}
POJ1703Find them, Catch them的更多相关文章
- POJ1703Find them, Catch them[种类并查集]
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 42416 Accepted: ...
- poj-1703-Find them, Catch them
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 41928 Accepted: ...
- poj1703--Find them, Catch them(并查集应用)
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 32073 Accepted: ...
- POJ1703-Find them, Catch them 并查集构造
Find them, Catch them 好久没有做并查集的题,竟然快把并查集忘完了. 题意:大致是有两个监狱,n个 ...
- poj--1703--Find them, Catch them(并查集巧用)
Find them, Catch them Time Limit: 1000MS Memory Limit: 10000KB 64bit IO Format: %I64d & %I64 ...
- poj1703Find them, Catch them(并查集以及路径压缩)
/* 题目大意:有两个不同的黑帮,开始的时候不清楚每个人是属于哪个的! 执行两个操作 A a, b回答a, b两个人是否在同一帮派,或者不确定 D a, b表示a, b两个人不在同一个帮派 思路:利用 ...
- POJ1703Find them, Catch them 【种类并查集】
题目链接:http://poj.org/problem?id=1703 题目大意:给n个人,m次询问.A代表询问a, b之间的关系,D代表给出a, b属于不同的帮派. 我的想法: 太菜了,上课的时候没 ...
- POJ1703--Find them, Catch them(种类并查集)
Time Limit: 1000MSMemory Limit: 10000K Total Submissions: 32909Accepted: 10158 Description The polic ...
- SQLServer如何添加try catch
在.net中我们经常用到try catch.不过在sqlserver中我们也可以使用try catch捕捉错误,在这里把语法记录下来和大家分享一下, --构建存储过程CREATE PROCEDURE ...
随机推荐
- OpenCV人脸检测demo--facedetect
&1 问题来源 在运行官网的facedetect这个demo的时候,总是不会出来result的图形,电脑右下角提示的错误是“显示器驱动程序已停止响应,而且已恢复 windows 8(R)”. ...
- pandas 练习
from pandas import Series, DataFrame # Series接收list或dict作为一维数据 #两个属性:values, index #① s1 = Series([4 ...
- Objective-c基础学习
核心内容 标识号 OC语言中,对各种变量,方法和类等要素命名时使用的字符序列称为标识符. OC标识符命名规则标识符由字母,下划线“_”,美元符号“$”和数字组成,标识符必须以字母,下划线,美元符号开头 ...
- vi 命令 用法
一.Unix编辑器概述 编辑器是使用计算机的重要工具之一,在各种操作系统中,编辑器都是必不可少的部件.Unix及其相似的ix 操作系统系列中,为方便各种用户在各个不同的环境中使用,提供了一系列的ex编 ...
- linux内核分析 第4章读书笔记
第四章 进程调度 一.抢占与非抢占 1.非抢占式进程调度 进程会一直执行直到自己主动停止运行 2.抢占式进程调度 Linux/Unix使用的是抢占式的方式,强制的挂起进程的动作就叫做抢占. 二.进程优 ...
- 讽刺的是,我在linux下使用最多的命令,竟然是windows的
$ history | awk '{print $2}' | sort | uniq -c | sort -nr | head dir vi echo cd vim jobs gcc ls less ...
- UIPasteboard的使用
剪贴板的使用以及自定义剪贴板. 系统剪贴板的直接调用 其实整个过程非常的简单,我就用我写的一个自定义UILable来说明调用系统剪贴板. 首先,因为苹果只放出来了 UITextView,UITextF ...
- 【MyEclipse 2015】 逆向破解实录系列【终】(纯研究)
声明 My Eclipse 2015 程序版权为Genuitec, L.L.C所有. My Eclipse 2015 的注册码.激活码等授权为Genuitec, L.L.C及其付费用户所有. 本文只从 ...
- 一条命令使win7可以直接运行.net3.5程序
dism /online /get-features 获取 功能名称 dism /online /enable-feature /featurename:NetFx3 启用win7自带的.net f ...
- beta版本贡献率
队名:攻城小分队 031302410 郭怡锋 : 占比:50% 031302411 洪大钊: 占比:30% 031302206 陈振贵: 占比:10% 031302416 黄伟祥: 占比:10%