小希的迷宫 HDU - 1272

判空是否成树

 #include <bits/stdc++.h>
 #define MAX_N 100010
 #define INF 1<<28
 using namespace std;
 bool cnt[MAX_N];
 int edge,V;
 int u,v;
 int main()
 {
   while(scanf("%d%d",&u,&v) != EOF) {
     if (u == -1 && v == -1) break;
 
     if (u != 0 && v != 0) {
       memset(cnt,0,sizeof cnt);
       V = 0;
       edge = 0;
       V+=2;
       cnt[u] = cnt[v] = true;
       edge++;
       while (scanf("%d%d",&u,&v) != EOF && (u + v)) {
         if (!cnt[u]){
           V++;
           cnt[u] = true;
         }
         if (!cnt[v]){
           cnt[v]= true;
           V++;
         }
         edge++;
       }
       if (edge == V - 1){
          printf("Yes\n");
       } else {
         printf("No\n");
       }
     } else {
       printf("Yes\n");
     }
 
   }
   return 0;
 }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值