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