Find them, Catch them
Time Limit: 1000MS   Memory Limit: 10000K
Total Submissions: 37722   Accepted: 11632

Description

The police office in Tadu City decides to say ends to the chaos, as launch actions to root up the TWO gangs in the city, Gang Dragon and Gang Snake. However, the police first needs to identify which gang a criminal belongs to. The present question is, given two criminals; do they belong to a same clan? You must give your judgment based on incomplete information. (Since the gangsters are always acting secretly.)

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

The first line of the input contains a single integer T (1 <= T <= 20), the number of test cases. Then T cases follow. Each test case begins with a line with two integers N and M, followed by M lines each containing one message as described above.

Output

For each message "A [a] [b]" in each case, your program should give the judgment based on the information got before. The answers might be one of "In the same gang.", "In different gangs." and "Not sure yet."

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

  1. POJ1703Find them, Catch them[种类并查集]

    Find them, Catch them Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 42416   Accepted: ...

  2. poj-1703-Find them, Catch them

    Find them, Catch them Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 41928   Accepted: ...

  3. poj1703--Find them, Catch them(并查集应用)

    Find them, Catch them Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 32073   Accepted: ...

  4. POJ1703-Find them, Catch them 并查集构造

                                             Find them, Catch them 好久没有做并查集的题,竟然快把并查集忘完了. 题意:大致是有两个监狱,n个 ...

  5. poj--1703--Find them, Catch them(并查集巧用)

    Find them, Catch them Time Limit: 1000MS   Memory Limit: 10000KB   64bit IO Format: %I64d & %I64 ...

  6. poj1703Find them, Catch them(并查集以及路径压缩)

    /* 题目大意:有两个不同的黑帮,开始的时候不清楚每个人是属于哪个的! 执行两个操作 A a, b回答a, b两个人是否在同一帮派,或者不确定 D a, b表示a, b两个人不在同一个帮派 思路:利用 ...

  7. POJ1703Find them, Catch them 【种类并查集】

    题目链接:http://poj.org/problem?id=1703 题目大意:给n个人,m次询问.A代表询问a, b之间的关系,D代表给出a, b属于不同的帮派. 我的想法: 太菜了,上课的时候没 ...

  8. POJ1703--Find them, Catch them(种类并查集)

    Time Limit: 1000MSMemory Limit: 10000K Total Submissions: 32909Accepted: 10158 Description The polic ...

  9. SQLServer如何添加try catch

    在.net中我们经常用到try catch.不过在sqlserver中我们也可以使用try catch捕捉错误,在这里把语法记录下来和大家分享一下, --构建存储过程CREATE PROCEDURE ...

随机推荐

  1. jquery.Deferred promise解决异步回调

    我们先来看一下编写AJAX编码经常遇到的几个问题: 1.由于AJAX是异步的,所有依赖AJAX返回结果的代码必需写在AJAX回调函数中.这就不可避免地形成了嵌套,ajax等异步操作越多,嵌套层次就会越 ...

  2. 【转】【C#】序列化(Serialize)、反序列化(Deserialize)

    序列化又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方. .NET框架提供了两种串行化的方式: 1. ...

  3. U3D 扩展方法 & Dotween & tolua

    using UnityEngine; using System.Collections; using LuaInterface;//tolua 空间引用 using DG.Tweening;//DOT ...

  4. R树空间索引

    R树在数据库等领域做出的功绩是非常显著的.它很好的解决了在高维空间搜索等问题.举个R树在现实领域中能够解决的例子吧:查找20英里以内所有的餐厅.如果没有R树你会怎么解决?一般情况下我们会把餐厅的坐标( ...

  5. g++编译总结

    g++编译&&gdb调试&&coredump调试 一.编译注意细节 1.使用g++编译CPP文件如果用gcc编译C++源文件时,加以下选项:-lstdc++,否则使用了 ...

  6. 每日一SQL-善用DATEADD和DATEDIFF

    转自:http://www.dotblogs.com.tw/lastsecret/archive/2010/10/04/18097.aspx 上個星期去Tech-Day聽了幾場有趣的課,其中一堂是楊志 ...

  7. 实现chrome扩展启动本地进程 - 补充

    实现chrome扩展启动本地进程 - 补充 标签: chrome扩展启动本地程序访问本地磁盘 2014-10-17 11:42 6753人阅读 评论(17) 收藏 举报  分类: Chrome Plu ...

  8. js第一天

    学习js的地址 http://www.w3school.com.cn/js/index.asp JS是一种轻量级的编程语言,插入html页面后可以由任何浏览器去执行,可用于 HTML 和 web,更可 ...

  9. 九度oj-1003-Java

    题目描述: 给定两个整数A和B,其表示形式是:从个位开始,每三位数用逗号","隔开. 现在请计算A+B的结果,并以正常形式输出. 输入: 输入包含多组数据数据,每组数据占一行,由两 ...

  10. Java系列: 关于HttpSessionListener的sessionDestroyed什么时候触发

    根据书本写了下面这个监听器,然后开始调试,打开一个浏览器来访问该网页,可以正常触发sessionCreated,然后关闭浏览器,发现没有触发sessionDestroyed,然后我怀疑是不是这个监听器 ...