题意:判断是不是一棵树
条件:无环,一个跟节点,看别人的代码要只有一个入度为0的结点,不存在入度大于1的结点
和hdu1272代码基本一样,只是这道是有向图,代码区别在了
if(l!=r&&l==y)
pre[l]=r;
无向图的话判断父节点不是一个点就好了,但是树的话一个点只能赋值一次父节点,比如1 2 1 2就错了,至于入度问题~我没理解诶。。
#include <iostream>
#include <stdio.h>
using namespace std;
#define N 1005
int flag;
int pre[N],vis[N],ru[N];
int find(int x)
{
int r=x;
while(pre[r]!=r)
r=pre[r];
return r;
}
void mix(int x,int y)
{
int r=find(x);
int l=find(y);
if(l!=r&&l==y)
pre[l]=r;
else
flag=0;
}
int main()
{
int a,b,num=0;
while(scanf("%d %d",&a,&b))
{
num++;
if(a<0&&b<0)
break;
if(a==0&&b==0)
{
printf("Case %d is a tree.\n",num);
continue;
}
for(int i=0;i<=N;i++)
pre[i]=i;
memset(vis,0,sizeof(vis));
flag=1;
mix(a,b);
vis[a]=vis[b]=1;
while(scanf("%d %d",&a,&b))
{
if(a==0&&b==0)
break;
vis[a]=vis[b]=1;
mix(a,b);
}
int sum=0;
for(int i=1;i<=N;i++)
{
if(vis[i]==1&&pre[i]==i)
sum++;
if(sum>1)
{
flag=0;
break;
}
}
if(flag)
printf("Case %d is a tree.\n",num);
else
printf("Case %d is not a tree.\n",num);
}
return 0;
}
/****************