zoukankan      html  css  js  c++  java
  • 寒假Day61:HDU1116Play on Words欧拉回路+并查集

    题目链接:

    题意:

    判断上一个单词的最后一个字母和下一个单词的第一个字母是否相同

    直接暴力WA

    AC代码:

     1 #include<iostream>
     2 #include<stdio.h>
     3 #include<string.h>
     4 #include<vector>
     5 #include<algorithm>
     6 #include<queue>
     7 using namespace std;
     8 typedef long long ll;
     9 
    10 const int N=30;
    11 bool book[N];
    12 int f[N],in[N],out[N];
    13 char s[1100];
    14 
    15 int getf(int x)
    16 {
    17     if(f[x]==x)
    18         return x;
    19     return f[x]=getf(f[x]);
    20 }
    21 
    22 void merge(int x,int y)
    23 {
    24     int t1=getf(x);
    25     int t2=getf(y);
    26     f[t2]=t1;
    27 }
    28 
    29 void init()
    30 {
    31     memset(book,0,sizeof(book));
    32     memset(in,0,sizeof(in));
    33     memset(out,0,sizeof(out));//in、out一定记得清空
    34     for(int i=0; i<26; i++)
    35         f[i]=i;
    36 }
    37 
    38 int main()
    39 {
    40     int t,n;
    41     scanf("%d",&t);
    42     while(t--)
    43     {
    44         init();
    45         scanf("%d",&n);
    46         for(int i=1; i<=n; i++)
    47         {
    48             scanf("%s",s);
    49             int len=strlen(s);
    50             int x=s[0]-'a',y=s[len-1]-'a';
    51             merge(x,y);
    52             in[y]++,out[x]++;
    53             book[x]=1,book[y]=1;
    54         }
    55         int w=0,x=0,y=0,z=0;
    56         for(int i=0; i<26; i++)
    57         {
    58             if(book[i]&&f[i]==i)
    59                 w++;
    60         }
    61         if(w>=2)
    62             printf("The door cannot be opened.\n");
    63         else
    64         {
    65             for(int i=0; i<26; i++)
    66             {
    67                 if(book[i])
    68                 {
    69                     if(in[i]!=out[i])
    70                         x++;
    71                     if(in[i]-out[i]==1)
    72                         y++;
    73                     if(out[i]-in[i]==1)
    74                         z++;
    75                 }
    76             }
    77             if(x==0)
    78                 printf("Ordering is possible.\n");
    79             else if(x==2&&y==1&&y==z)
    80                 printf("Ordering is possible.\n");
    81             else
    82                 printf("The door cannot be opened.\n");
    83         }
    84     }
    85     return 0;
    86 }
    View Code
  • 相关阅读:
    Tree UVA
    stringstream的使用
    Trees on the level UVA
    strchr和strstr函数
    sscanf的用法
    Dropping Balls UVA
    Boxes in a Line UVA
    Broken Keyboard (a.k.a. Beiju Text) UVA
    Matrix Chain Multiplication (堆栈)
    出栈次序
  • 原文地址:https://www.cnblogs.com/OFSHK/p/12601642.html
Copyright © 2011-2022 走看看