3 43 11 1 4 3 2 3 3 1 4 1 1 4 4 2 3 3 1 2 2 2 1 4 1 1 1 2 1 4 2 3 4 2 3 2 66 9 2 3 1 2 4 4 2 1 2 2 4 3 2 4 2 2 2 3 1 3 2 1 2 1 1 1 1 6 7 2 3 7 2 1 2 2 4 4 1 2 1 1 3 2 1 2 3 2 1 3
5 4 3
这题是食物链那题改编的,思路一模一样。今天重写了这道题,结果WA,反复差错,折腾了一个小时,才发现是变量使用错了,把变量的含义弄错了,哎,定义什么变量,一定要清楚它代表的是什么含义,否则。。。
代码:
#include <iostream> #include <stdio.h> using namespace std; const int N=10002; int parent[N]; void init(int n) { for(int i=1;i<=n;i++) parent[i]=i; } int find(int x) { return parent[x]==x?x:find(parent[x]); } void unite(int x,int y) { x=find(x); y=find(y); if(x==y) return; parent[x]=y; } bool same(int x,int y) { return find(x)==find(y); } int main() { int t;cin>>t; int n,m,d,x,y; while(t--) { cin>>n>>m;//注意变量的含义,n代表的是n个人 init(3*n); int lie=0; for(int i=1;i<=m;i++) { cin>>d>>x>>y; if(x>n||y>n||(x==y&&d==2)) { lie++; continue; } if(d==1) { if(same(x,y+n)||same(x,y+2*n))//+n,别写成+m lie++; else { unite(x,y); unite(x+n,y+n); unite(x+2*n,y+2*n); } } else { if(same(x,y)||same(x,y+2*n)) lie++; else { unite(x,y+n); unite(x+n,y+2*n); unite(x+2*n,y); } } } cout<<lie<<endl; } return 0; }
[ACM] 携程预赛第二场 剪刀石头布(并查集),布布扣,bubuko.com
原文:http://blog.csdn.net/sr_19930829/article/details/23740805