LeetCode127. 单词接龙

2023-10-28 20:59
文章标签 单词 接龙 leetcode127

本文主要是介绍LeetCode127. 单词接龙,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣

 

解题思路: 像这种BFS类型的题都有类似的模板

1.  通过 BFS, 首先用 beginWord 带出转换一个字母之后所有可能的结果
2. 每一步都要把队列中上一步添加的所有单词转换一遍,最短的转换肯定在这些单词当中, 所有这些词的转换只能算一次转 换,因为都是上一步转换出来的,这里对于每个单词的每个位置都可以用26 个字母进行转换,所以一个单词一次转换的可能 有:单词的长度 * 26
3.  把转换成功的新词入队,进行下一步的转换
4.  最后整个转换的长度就和 BFS 执行的次数相同

优化:
①  使用unordered_set<string>  存储 字典中的单词,查找效率高
     使用unordered_set<string>  存储 已经查找过的单词,防止死循环。

②    如果使用两个同时进行的广搜可以有效地减少搜索空间。一边从 beginWord 开始,另一边从 endWord 开始。我们每次从两边各扩展一层节点,当发现某一时刻两边都访问过同一顶点时就停止搜索

更好的理解 ->  B站 : 花花酱

1.单向BFS

class Solution 
{
public:int ladderLength(string beginWord, string endWord, vector<string>& wordList) {//hash表的查询效率最高 unordered_set<string> wordDict(wordList.begin(), wordList.end()); unordered_set<string> visited; //标记单词是否已经访问过,访问过的不再访问 visited.insert(beginWord); queue<string> q; //初始化队列 q.push(beginWord); int res = 1; while (!q.empty()){ int nextSize = q.size(); //每一步都要把队列中上一步添加的所有单词转换一遍 //最短的转换肯定在这些单词当中, 所有这些词的转换只能算一次转换//因为都是上一步转换出来的 while (nextSize--){ string curWord = q.front(); q.pop(); if(curWord == endWord)return res;for (int i = 0; i < curWord.size(); i++)//尝试转换当前单词的每一个位置 { string newWord = curWord; for (char ch = 'a'; ch <= 'z'; ch++)//每一个位置用26个字母分别替换 {newWord[i] = ch; //判断新的单词是否在词典中,且没有搜索过if (wordDict.find(newWord) != wordDict.end()&& visited.find(newWord) == visited.end()) {visited.insert(newWord); //标记已使用q.push(newWord); }} }}++res; //转换成功  }//转换不成功,返回0 return 0;}
};

2.双向BFS

class Solution {
public:int ladderLength(string beginWord, string endWord, vector<string>& wordList) {//双向广度优先搜索unordered_set<string> dict(wordList.begin() , wordList.end());if(dict.find(endWord) == dict.end())return 0;// 分别用左边和右边扩散的哈希表代替单向 BFS 里的队列,它们在双向 BFS 的过程中交替使用unordered_set<string> q1{beginWord}; //从前向后搜索unordered_set<string> q2{endWord}; //从后向前搜索int len = beginWord.size();//执行双向 BFS,左右交替扩散的步数之和为所求int ans = 0;while(!q1.empty() && !q2.empty()){++ans;// 优先选择小的哈希表进行扩散,考虑到的情况更少if(q1.size() > q1.size())std::swap(q1,q2);unordered_set<string> q;//遍历原来哈希表中的单词 ,产生的新的序列保存在这里//这里遍历每一个节点的单词,然后修改其中一个字符,让他成为一个新的单词,//并查看这个新的单词在字典中是否存在,如果存在并且没有被访问过,就加入到队列中for(string str : q1){for(int i = 0 ; i < len ;++i){char ch = str[i];for(char ch = 'a' ; ch <= 'z' ;++ch){str[i] = ch;if (q2.find(str) != q2.end()) return ans + 1;if (dict.find(str) == dict.end()) continue;dict.erase(str);q.insert(str);}str[i] = ch;}}std::swap(q , q1);//将新的序列和老的序列交换}return  0 ;}
};

这篇关于LeetCode127. 单词接龙的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/295921

相关文章

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

动态规划---单词拆分

题目: 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。 注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。 思路:本题属于完全背包问题,字符串s的长度为背包容量,字符串列表wordDict中的每一个元素相当于物品。 动态规划五部曲: 1.确定dp数组及含义 dp数组为元素类型是布

WPS如何查看已添加到词典的单词

WPS Office(12.1.0.17827) ① 点击文件,在文件中找到选项 ② 找到拼写检查并点击自定义词典 ③ 如果要删除已添加到词典的"错词",则点击修改 ④ 选择"错词", 点击删除

【C】单词长度

课程:程序设计入门——C语言(翁恺) 题目内容: 你的程序要读入一行文本,其中以空格分隔为若干个单词,以‘.’结束。你要输出这行文本中每个单词的长度。这里的单词与语言无关,可以包括各种符号,比如“it's”算一个单词,长度为4。注意,行中可能出现连续的空格。 输入格式: 输入在一行中给出一行文本,以‘.’结束,结尾的句号不能计算在最后一个单词的长度内。 输出格式: 在一行中输出这行

代码随想录第八天|151.翻转字符串里的单词 卡码网:55.右旋转字符串 28. 实现 strStr() 459.重复的子字符串

反转字符串的单词 思路:刷过稍微忘记 class Solution {public://去除空格string remove(string s){//使用快慢指针int slow=0;int i=0;for(;i<s.size();i++){if(s[i]!=' '){if(slow!=0){s[slow++]=' ';}while(s[i]!=' '&&i<s.size()){s[slow+

实操在聆思CSK6大模型开发板的英文评测SDK中自定义添加单词、短语、句子资源

引言 英文评测示例通过对用户语音输入的英文单词进行精准识别,提供 单词、短语、句子 三种类型,用户在选择好类型后,可根据屏幕上的提示进行语音输入,评测算法将对输入的英文语音进行精准识别,并对单词的发音、错读、漏读、多读等方面进行评估。 本文将详细介绍在聆思CSK6大模型语音视觉开发板上,如何替换英文评测示例中的单词、短语和句子,从而让您有更好的AI应用体验。 ·· 获取英文评测SDK 部

我用ChatGPT编写一个英语猜单词游戏源码

一、背景 我们可以利用python中的tkinter框架创建一个简单的英语单词猜词游戏。用户将看到一个缺少几个字母的单词,并需要填写出正确的字母,填写正确后会提醒correct,错误则提示:try again. 本代码全程利用VScode中的ChatGPT插件来完成。 二、实现过程 步骤 1:导入必要的库 我们需要导入 tkinter 库来创建图形用户界面(GUI),还需要导入 rando

【算法】单词出现次数和位置统计

【算法】单词出现次数和位置统计 题目描述 编写一个程序,用于统计一个给定单词在一段文本中出现的次数以及第一次出现的位置。如果单词在文本中出现,则输出出现次数和第一次出现的位置(位置从0开始计算)。如果单词没有出现,则输出-1。 思路分析 使用Scanner类从控制台读取两个字符串:要搜索的文本str和要统计的单词substring。定义一个方法countStr,该方法接收两个字符串参数

sql 中名字 不可以 包含 mysql中 具有 特定意义 的单词

这种sql执行不报错 这种sql执行报错 所以sql中名字不可以使用mysql中具有特定意义的单词 以此文章作为警告,我下次起名字不可以使用 mysql中具有特殊意义的字符 就因为这个导致我搞了一个多小时,急死我了,周五就要前后端联调了。下次千万不能随便起名字了

从laborer一词掌握单词记忆的秘诀

记忆任何一个单词,毫无疑问,所有的人都可以拥有和使用一种原始的记忆方法,那就是逐个字母地拼读、拼写,反复地拼读、拼写,进行记忆,这种方法,被称为机械式记忆方法。 一、拼读记忆法 比如laborer这个单词: laborer n.劳动者,苦力;工人,劳工 你也可以这样去记忆: laborer = l + a + b + o + r + e + r = 劳动者 我们在记忆的时候