首页 > 代码库 > HDU1272 小希的迷宫(基础并查集)
HDU1272 小希的迷宫(基础并查集)
杭电的图论题目列表,共计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; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。