首页 > 其他 > 详细

hdu 1116 Play on Words

时间:2015-06-12 22:12:58      阅读:257      评论:0      收藏:0      [点我收藏+]

并查集+有向欧拉回路 有向欧拉通路的判定。

并查集用来判断是不是连通图。

#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;

const int maxn=100010;
int sumru[maxn],sumchu[maxn],father[30],flag[30],ff[30];
char s[1000];

int findd(int x)
{
    if(x!=father[x]) father[x]=findd(father[x]);
    return father[x];
}

int main()
{
    int T;
    scanf("%d",&T);
    while(T--)
    {
        int n,i;
       
        scanf("%d",&n);
        memset(sumru,0,sizeof(sumru));
        memset(sumchu,0,sizeof(sumchu));
        memset(flag,0,sizeof(flag));
        memset(ff,0,sizeof(ff));
        for(i=0;i<=25;i++) father[i]=i;

        for(i=0;i<n;i++)
        {
            scanf("%s",s);
            sumru[s[strlen(s)-1]-a]++;
            sumchu[s[0]-a]++;
            int ft=findd(s[0]-a);
            int fw=findd(s[strlen(s)-1]-a);
            if(ft!=fw) father[ft]=fw;
            flag[s[strlen(s)-1]-a]=1;
            flag[s[0]-a]=1;
        }

        int jieguo=1,tott=0;
        int uu[maxn];

        for(i=0;i<=25;i++) if(flag[i]==1) ff[findd(i)]=1;
        for(i=0;i<=25;i++) if(ff[i]==1) tott++;
        if(tott!=1)jieguo=0; 
        tott=0;
        if(jieguo==1)
        {
            for(i=0;i<=25;i++)
            {
                if(sumru[i]==0&&sumchu[i]==0) continue;//这个点没有出现
                if(sumru[i]==sumchu[i]) continue;
                if(sumru[i]!=sumchu[i])
                {
                    uu[tott]=i;
                    tott++;
                }
            }
            if(tott!=2&&tott!=0) jieguo=0;
            if(tott==2)
            {
                if((sumru[uu[0]]-sumchu[uu[0]]==1&&sumru[uu[1]]-sumchu[uu[1]]==-1)||(sumru[uu[0]]-sumchu[uu[0]]==-1&&sumru[uu[1]]-sumchu[uu[1]]==1)) jieguo=jieguo;
                else jieguo=0;
            }
        }
        
        if(jieguo==0) printf("The door cannot be opened.\n");
        else printf("Ordering is possible.\n");
    }
    return 0;
}

 

hdu 1116 Play on Words

原文:http://www.cnblogs.com/zufezzt/p/4572667.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!