HDU-1272-小希的迷宫
http://acm.hdu.edu.cn/showproblem.php?pid=1272
基本的并查集
#include<iostream>
#include<cstdio>
using namespace std;
#define N 100010
int f[N];
int mark[N];
int find(int x)
{
int r=x;
while(f[r]!=r)
r=f[r];
f[x]=r;
return f[x];
}
void merege(int x,int y)
{
f[x]=y;
}
int main()
{
int min,max;
int a,b,flag,aa,bb,count,i;
while(scanf("%d%d",&a,&b)!=EOF)
{
if(a==-1&&b==-1)
break;
if(a==0&&b==0)
{
printf("Yes\n");
continue;
}
flag=0;
for(i=1;i<100010;i++)
f[i]=i;
memset(mark,0,sizeof(mark));
max=-1;
min=99999999;
while(a||b)
{
if(a>max)
max=a;
if(b>max)
max=b;
if(a<min)
min=a;
if(b<min)
min=b;
mark[a]=mark[b]=1;
aa=find(a);
bb=find(b);
if(aa==bb)
flag=1;
else
merege(aa,bb);
scanf("%d%d",&a,&b);
}
if(flag)
{
printf("No\n");
continue;
}
count=0;
for(i=min;i<=max;i++)
if(mark[i]&&f[i]==i)
count++;
if(count==1)
printf("Yes\n");
else
printf("No\n");
}
return 0;
}
分享到:
相关推荐
hdu-acm源代码(上百题)hdu-acm源代码、hdu-acm源代码hdu-acm源代码
算法-迷宫城堡(HDU-1269)(包含源程序).rar
算法-数塔(HDU-2084).rar
算术(HDU-6715).rar
算法-确定比赛名次(HDU-1285).rar
最短路(HDU-2544).rar
算法-连连看(HDU-1175)(包含源程序).rar
算法-命运(HDU-2571)(包含源程序).rar
算法-欧拉回路(HDU-1878)(包含源程序).rar
算法-免费馅饼(HDU-1176)(包含源程序).rar
算法-六度分离(HDU-1869)(包含源程序).rar
算法-排列2(HDU-1716)(包含源程序).rar