搜索---HDU 1181 变形课

D - 变形课
Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u
Submit   Status

Description

呃......变形课上Harry碰到了一点小麻烦,因为他并不像Hermione那样能够记住所有的咒语而随意的将一个棒球变成刺猬什么的,但是他发现了变形咒语的一个统一规律:如果咒语是以a开头b结尾的一个单词,那么它的作用就恰好是使A物体变成B物体.  
Harry已经将他所会的所有咒语都列成了一个表,他想让你帮忙计算一下他是否能完成老师的作业,将一个B(ball)变成一个M(Mouse),你知道,如果他自己不能完成的话,他就只好向Hermione请教,并且被迫听一大堆好好学习的道理.  

Input

测试数据有多组。每组有多行,每行一个单词,仅包括小写字母,是Harry所会的所有咒语.数字0表示一组输入结束.  

Output

如果Harry可以完成他的作业,就输出"Yes.",否则就输出"No."(不要忽略了句号)  

Sample Input

so
soon
river
goes
them
got
moon
begin
big
0

Sample Output

Yes.


        
  
Harry 可以念这个咒语:"big-got-them".

Hint

 
        
Hint


简单深搜:先判定一下有没有m结尾的单词,然后再dfs,注意记录一下已经被挑选过的单词。


代码如下:


#include

#include

#include

using namespace std;


int n, use[1111];
char str[1111][1111];
int key;

void dfs(int a) {
    int len;
    len = strlen(str[a]);
    if (str[a][len - 1] == 'm') {    //如果这个单词本身就是以m结尾
        key = 1;
        return;
    }
    for (int i = 0; i < n; i++) {    //从第一个单词开始寻找
        if (str[i][0] == str[a][len - 1] && use[i] == 0) {     //如果第i个单词的开头与第a个单词的结尾相等,且没有找过
            use[i] = 1;             //标记为已找过
            dfs(i);
            use[i] = 0;           //关键点,如果从第i个单词搜一遍不符合,则要将其标为没走过
        }
    }
}

int main() {
    while (scanf("%s", str[0]) != EOF) {
        memset(use, 0, sizeof(use));
        int i, flag = 0;
        n = 1, key = 0;
        while (1) {                     //循环输入单词,直到遇到0位置
            scanf("%s", str[n]);
            int len;
            len = strlen(str[n]);
            if (str[n][len - 1] == 'm')            //如果存在以m结尾的单词,进行标记
                flag = 1;
            if (str[n][0] == '0')
                break;
            n++;
        }
        if (!flag)                   //如果不存在以m结尾的单词,直接输出No.
            printf("No.\n");
        else
        {                      //如果存在以m结尾的单词
            for (int i = 0; i < n; i++)
            {                  //从第一个单词开始搜索以b开头的单词
                if (str[i][0] == 'b')
                    dfs(i);
            }
            if (key)                 //如果可以找到收尾相连的单词组合
                printf("Yes.\n");
            else
                printf("No.\n");
        }
    }
    system("pause");
    return 0;
}



你可能感兴趣的:(搜索)