哈理工OJ 1490 咒语(BFS广度优先搜索)

来源:互联网 发布:vb.net 数据库教程 编辑:程序博客网 时间:2024/05/08 15:41

咒语
Time Limit: 1000 MS Memory Limit: 65535 K
Total Submit: 162(37 users) Total Accepted: 53(35 users) Rating: Special Judge: No
Description
小w同学为了学好自己喜欢的ACM,一直fighting着……一天小w同学在做题的过程中睡着了….梦里小w同学遇到了阿拉神灯,阿拉神灯说可以帮小w同学实现一个愿望,只要通过念一些咒语即可,这些咒语是由一个个长度不超过50 的单词组成的,变化的规则是让单词的第一个字母代表的事物拥有单词的最后一个字母代表的物品,例如,apple,表示可以让‘a’事物拥有 ‘e’ 物品。小w同学说想让自己s (self)有一对翅膀w(wing),这样自己就可以去任何想去的地方了,于是阿拉神灯就说出了一些咒语….小w同学能实现自己的愿望么?

Input
Line 1: 一个整数 n (1 <= n <= 200),表示咒语中包含单词的个数

Line 2..n+1: 每行一个长度不超过50的单词

Output
Line 1: 如果可以实现愿望(即存在从字母’s’ 到字母’w’ 的单词路线),输出“Yes”,否则输出“No”.
Sample Input
4

fly

self

raw

year

Sample Output
Yes
Hint
self-fly-year-raw
Author
wind

其实挺简单的,思路对了就OK了。可以把题目化为一个从s到w的广度优先搜索。

下面是AC代码:

#include<cstdio>#include<cstring>#include<queue>#include<algorithm>using namespace std;int a[27][27],book[27][27];int bfs(int s,int e){    int num;    queue<int>q;    q.push(s);    while(!q.empty())    {        num=q.front();        q.pop();        if(num==e)        {            return 1;        }        for(int i=0; i<26; i++)        {            if(a[num][i]&&book[num][i]==0)            {                q.push(i);                book[num][i]=1;            }        }    }    return 0;}char s[105];int main(){    int n;    while(~scanf("%d",&n))    {        memset(a,0,sizeof(a));        memset(book,0,sizeof(book));        for(int i=0; i<n; i++)        {            scanf("%s",s);            int l=strlen(s);            a[s[0]-'a'][s[l-1]-'a']=1;        }        int re=bfs('s'-'a','w'-'a');        if(re==0)            printf("No\n");        else printf("Yes\n");    }    return 0;}
0 0