05:单词序列MOOC程序设计算法基础期末第五题
2018-12-02 17:39
155 查看
给出两个单词(开始单词和结束单词)以及一个词典。找出从开始单词转换到结束单词,所需要的最短转换序列。转换的规则如下:
1、每次只能改变一个字母
2、转换过程中出现的单词(除开始单词和结束单词)必须存在于词典中
例如:
开始单词为:hit
结束单词为:cog
词典为:[hot,dot,dog,lot,log,mot]
那么一种可能的最短变换是: hit -> hot -> dot -> dog -> cog,
所以返回的结果是序列的长度5;
注意:
1、如果不能找到这种变换,则输出0;
2、词典中所有单词长度一样;
3、所有的单词都由小写字母构成;
4、开始单词和结束单词可以不在词典中。
输入
共两行,第一行为开始单词和结束单词(两个单词不同),以空格分开。第二行为若干的单词(各不相同),以空格分隔开来,表示词典。单词长度不超过5,单词个数不超过30。
输出
输出转换序列的长度。
样例输入
[code]hit cog hot dot dog lot log
样例输出
[code]5
bfs
AC代码:
[code]#include<iostream> #include<vector> #include<queue> #include<map> using namespace std; bool judge(string a,string b){//判断两单词是否只是有一个字母不同 int cnt=0; for(int i=0;i<a.size();++i) if(a[i]!=b[i]) ++cnt; if(cnt==1) return true; else return false; } int main() { string tmp,start,final; vector<string> pq;//存中间单词 cin>>start>>final; while(cin>>tmp) pq.push_back(tmp); pq.push_back(final);//将目的单词推入 queue<string> yu;map<string,int> op;op的值代表在转换序列中的顺序 yu.push(start);op[start]=1; int flag=0; while(1){ if(!yu.empty()) tmp=yu.front(),yu.pop(); else break; if(tmp==final) {flag=1;break;} for(int i=0;i<pq.size();++i) if(judge(pq[i],tmp)&&!op.count(pq[i])) yu.push(pq[i]),op[pq[i]]=op[tmp]+1; } if(flag) cout<<op[final]; else cout<<0; return 0; }
相关文章推荐
- 06:SudokuMOOC程序设计算法基础期末第六题
- 07:画家问题MOOC程序设计算法基础期末第七题
- 08:Calling Extraterrestrial Intelligence AgainMOOC程序设计算法基础期末第八题
- poj1222(开关灯来自(程序设计与算法(二)算法基础mooc))
- 09:最大子矩阵MOOC程序设计算法基础期末第九题
- 九章算法面试题25 反转单词序列
- 算法竞赛入门经典:第六章 数据结构基础 6.9 根据二叉树的后序和中序确定前序序列
- 中国大学MOOC-数据结构基础习题集、05-2、Saving James Bond - Easy Version
- 2017年浙江工业大学大学生程序设计迎新赛决赛—网络同步赛 D-序列【莫队算法】
- js基础算法之 找到字符串中最长的单词
- Python程序设计与算法基础教程·第二章上机实践
- 算法基础-例1:求有限整数序列中最大值的算法
- 2017年浙江工业大学大学生程序设计迎新赛决赛—网络同步赛 D-序列【莫队算法】
- 深度学习基础模型算法原理及编程实现--05.卷积神经网络
- 两个基础算法最大子序列和和最大公因子数
- C++程序设计:基础、编程抽象与算法策略的笔记
- zjnu(1183)——括号序列【基础算法・动态规划】——高级
- 【基础算法】(05)五大常用算法之一:分治算法
- * 深度优先搜索(1) 编程题#1: 棋盘问题(Coursera 程序设计与算法 专项课程4 算法基础;递归+剪枝!)
- Coursera_程序设计与算法_计算导论与C语言基础_数组应用练习