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. 创建文本,innerHTML与createTextNode的使用

    第一种:innerHTML p.innerHTML="124"; 除了这个还可以console.log(p.innerHTML) 弹出p里面的内容; 第二种:createTextN ...

  2. Web项目构建

    Gradle为Web开发提供了两个插件,war和jetty apply plugin: 'war' apply plugin: 'jetty' war插件继承了java插件,jetty插件继承了war ...

  3. 在创维E900-S悦Me盒子上安装第三方软件

    0x00 不甘寂寞 创维E900-S这款悦Me盒子功能还算可以,但不能接受它禁止安装第三方软件这一点.网上搜了半天,可能是比较新的机型没人关注,找不到任何方法,只好自己动手试试. 0x01 Fiddl ...

  4. SQL SERVER with递归示例一则

    WITH SUBQUERY AS ( SELECT ORGID FROM OM_ORGANIZATION WHERE PARENTORGID = 'ROOT' UNION ALL SELECT B.O ...

  5. C/C++关于string.h头文件和string类

    学习C语言时,用字符串的函数例如stpcpy().strcat().strcmp()等,要包含头文件string.h 学习C++后,C++有字符串的标准类string,string类也有很多方法,用s ...

  6. dxut.h(29): fatal error C1083: Cannot open include file: 'dxsdkver.h': No such file or directory

    从网上download一个三维演示模型的软件编译发现报找不到dxsdkver.h文件,网上查阅这是MS的DirectX sdk中的库文件,于是先download DirectX SDK 安装之后,配置 ...

  7. [CareerCup] 6.5 Drop Eggs 扔鸡蛋问题

    6.5 There is a building of 100 floors. If an egg drops from the Nth floor or above, it will break. I ...

  8. CAS ticket过期策略

    CAS提供可扩展的ticket过期策略,支持ticket-granting tickets (TGT)和service tickets (ST)的配置. CAS客户端存储用户信息一般使用session ...

  9. 从实用主义深入理解c++虚函数

    记得几个月前看过C++虚函数的问题,当时其实就看懂了,最近笔试中遇到了虚函数竟然不太确定,所以还是理解的不深刻,所以想通过这篇文章来巩固下. 装逼一刻: 最近,本人思想发生了巨大的转变,在大学的时候由 ...

  10. 数据结构之链表C语言实现以及使用场景分析

    牢骚:本篇博客两个星期前已经存为草稿,鉴于发生一些糟糕的事情,今天才基本完成.本人6月份应届毕业生一枚,毕业后当天来到帝都,之后也非常顺利,面试了俩家公司都成功了.一家做C++方面电商ERP,一家做w ...