Time Limit: 1000MS | Memory Limit: 10000K | |
Total Submissions: 31412 | Accepted: 9677 |
Description
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.
题解及代码:
一开始的思路有问题,本来想将最开始的两个人设为基点,因为他们两个必然对立,然后看后来人和他们的关系来判断,后来的人的关系。但是会出现,后面的人与一开始的人没关系的情况,所以wa了。
1.开始改变思路,我们使用一个set数组来记录某个人对立阵营的一个人,当判断两个人的关系时,首先我们看两个人是否在同一个root中,如果在即为一个阵营,然后我们可以判断前一个人与后一个人的set中人物的关系,如果root相同即为不同阵营,否则就是还未确定。
#include <iostream> #include <cstdio> using namespace std; int root[100010],set[100010]; int n,m; void init() { for(int i=0;i<=n;i++) root[i]=i,set[i]=0; } int look(int n) { if(n!=root[n]) root[n]=look(root[n]); return root[n]; } void _union(int a,int b) { a=look(a); b=look(b); if(a==b) return; root[b]=a; } int main() { int cas; scanf("%d",&cas); while(cas--) { scanf("%d%d",&n,&m); init(); char s[2]; int a,b; while(m--) { scanf("%s%d%d",s,&a,&b); if(s[0]=='A') { a=look(a); b=look(b); if(a==b) { printf("In the same gang.\n"); } else if(look(set[a])==b||look(set[b])==a) { printf("In different gangs.\n"); } else printf("Not sure yet.\n"); } else { if(!set[a]&&!set[b]) {set[a]=b,set[b]=a;} else if(!set[a]) set[a]=b,_union(set[b],a); else if(!set[b]) set[b]=a,_union(set[a],b); else _union(set[a],b),_union(set[b],a); } } } return 0; }
2.我们可以是一个数组来记录,每个节点与起父节点的关系,在查找和合并的时候都需要更新这个数组。
#include <iostream> #include <cstdio> using namespace std; int root[100010],rela[100010]; int n,m; void init() { for(int i=0; i<=n; i++) root[i]=i,rela[i]=0; } int look(int n) { int t=root[n]; if(n!=root[n]) root[n]=look(root[n]); rela[n]=(rela[n]==rela[t])?0:1; return root[n]; } void _union(int a,int b,int ra,int rb) { root[rb]=ra; rela[rb]=(rela[a]==rela[b])?1:0; } int main() { int cas; scanf("%d",&cas); while(cas--) { scanf("%d%d",&n,&m); init(); char s[2]; int a,b; while(m--) { scanf("%s%d%d",s,&a,&b); if(s[0]=='A') { int ra=look(a); int rb=look(b); if(ra==rb) { if(rela[a]==rela[b]) printf("In the same gang.\n"); else printf("In different gangs.\n"); } else printf("Not sure yet.\n"); } else { int ra=look(a),rb=look(b); _union(a,b,ra,rb); } } } return 0; }
poj 1703 Find them, Catch them,布布扣,bubuko.com
poj 1703 Find them, Catch them
原文:http://blog.csdn.net/knight_kaka/article/details/38513175