杭电的图论题目列表。共计500题,努力刷吧

AC 64ms

#include <iostream>
#include <cstdlib>
#include <cstdio>
#include <cstring>
#include <algorithm>
const int INF = 1e8;
using namespace std;
int father[100010];
bool vis[100010];
int findx(int r)
{
int i = r,j;
while(father[r]!=r)
{
r=father[r];
} while(father[i]!=r)
{
j = father[i];
father[i] = r;
i = j;
}
return r;
} bool Merge(int x,int y)
{
int fx,fy;
fx=findx(x);
fy=findx(y);
if(fx!=fy)
{
father[fx]=fy;
return 1;
}
else
return 0;
}
void init()
{
for(int i=0;i<100010;i++)
{
father[i]=i;
vis[i]=0;
}
}
int main()
{
int a,b;
while(scanf("%d%d",&a,&b)!=EOF)
{
if(a==-1&&b==-1)
break;
int flag=1,t=0;
if(a==0 && b==0)
{
puts("Yes");
continue;
}
init();
int num = 0;
while(1)
{
if(a==0&&b==0) break;
if(flag)
{
if(!vis[a]) num++; //num记录点数
if(!vis[b]) num++;
vis[a]=1; vis[b]=1;
if(Merge(a,b)==1)
t++; //t记录边数
else
flag = 0;
}
scanf("%d%d",&a,&b);
}
if(num-t==1 &&flag == 1)//满足题意的仅仅能是 点数-边数==1
puts("Yes")
else
puts("No");
}
return 0;
}

05-08 08:43