poj 1386 欧拉回路判定

奇怪的是,我的判定是不是联通的部分出问题了

先贴个对的:

#include <cstdio>
#include <map>
#include <cstring>
#include <string>
#include <iostream>
using namespace std;

const int SIZE = 100000+10;
const int SSIZE = 1000 +10;
const int tb = 26;

int idx(char x)
{
    return x-'a';
}

int n,parent[tb],ideg[tb],odeg[tb],e[tb];

void init()
{
    for(int i=0;i<tb;i++)
    {
        parent[i]=i;
        e[i]=ideg[i]=odeg[i]=0;
    }
}

int Find(int x)
{
    if(x!=parent[x])parent[x]=Find(parent[x]);
    return parent[x];
}

void Union(int x, int y)
{
    x=Find(x);
    y=Find(y);
    if(x!=y)parent[y]=x;
}

int main()
{
    //freopen("poj1386.txt","r",stdin);
    int ncase;
    char str[SIZE];
    scanf("%d",&ncase);
    while(ncase--)
    {
        int u,v;
        scanf("%d",&n);
        init();
        for(int i=0;i<n;i++)
        {
            scanf("%s",str);
            ideg[ u=idx( str[strlen(str)-1]) ]++;
            odeg[ v=idx( str[0]) ]++;
            e[u]=e[v]=1;
            Union(u, v);
        }

        int connect=1,tmp=Find(u);

        for(int i=0;i<tb;i++)
        {
            if(e[i]&&tmp!=Find(i))
            {
                connect=0;
                break;
            }
        }

        if(!connect)
        {
            printf("The door cannot be opened.\n");
            continue;
        }
        /*int scnt=0;
        for(int i=0;i<tb;i++)
            if(e[i] && Find(i) == i)
                scnt++;
        if(scnt>1)
        {
            printf("The door cannot be opened.\n");
            continue;
        }*/

        int acnt=0,bcnt=0,cnt=0;
        for(int i=0;i<tb;i++)
            if(e[i])
            {
                if(ideg[i] == odeg[i])continue;
                if(ideg[i] == odeg[i]+1 )
                {
                    acnt++;
                    continue;
                }
                if(odeg[i] == ideg[i]+1 )
                {
                    bcnt++;
                    continue;
                }
                cnt++;
            }
        //if(cnt){printf("The door cannot be opened.\n");continue;}
        if((!acnt&&!bcnt&&!cnt) || (acnt==1&&bcnt==1&&cnt==0))printf("Ordering is possible.\n");
        //if(acnt<=1 && bcnt<=1)printf("Ordering is possible.\n");
        else printf("The door cannot be opened.\n");
    }
    return 0;
}

但是这样判断联通就WA得很惨,不晓得为什么,求大神指教:
        int connect=1,tmp,i;
        for(i=0;i<tb;i++)
            if(e[i])
            {
                tmp=Find(i);
               // i--;
                break;
            }

        for(;i<tb;i++)
            if(e[i] && tmp!=Find(i))
        {
            connect=0;
            break;
        }


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值