哈理工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
- 哈理工OJ 1490 咒语(BFS广度优先搜索)
- 哈理工OJ 2035 Diablo(多次广度优先搜索+详解)
- 哈理工OJ 1316 移动 II (广度优先搜索+路径打印)
- 广度优先搜索(BFS)
- 广度优先搜索(BFS)
- 广度优先搜索(BFS)
- 广度优先搜索(BFS)
- BFS(广度优先搜索)
- 哈理工oj 1490咒语【基础并查集】
- 搜索(广度优先搜索) BFS 1
- 搜索(广度优先搜索)BFS 2
- 广度优先搜索-BFS
- BFS广度优先搜索
- 广度优先搜索 BFS
- 广度优先搜索(BFS)
- 广度优先搜索(BFS)
- 广度优先搜索(BFS)
- BFS (广度优先搜索)
- bzoj1036: [ZJOI2008]树的统计Count
- java如何判断一个String类型数据由多少字节组成?
- Linux下Tcp 编程
- [笔记]cin、cout与scanf、printf的效率差异对比分析
- Android的Drawable体系
- 哈理工OJ 1490 咒语(BFS广度优先搜索)
- mysql 5.7.11压缩版 +Navicat 安装
- Java虚拟机规范----JVM体系结构
- UVA-1586
- QT D-Bus 复杂参数传递
- 通过cmd命令,使用VS2010的C++编译器编译源文件
- 设计模式——观察者模式
- Java网络编程笔记--实现UDP广播发送与接收
- 通过TurtleBot学navigation与ROS的笔记