博客
关于我
126. 单词接龙 II
阅读量:562 次
发布时间:2019-03-09

本文共 1791 字,大约阅读时间需要 5 分钟。

为了解决从 beginWordendWord 的最短转换序列问题,我们可以使用广度优先搜索(BFS)来找到所有可能的最短路径。每次转换只能改变一个字母,并且中间单词必须在给定的字典中。

方法思路

  • 预处理:首先,检查所有单词的长度是否一致。如果不一致,直接返回空列表。
  • 构建字典映射:使用哈希表(字典)存储单词及其对应的位置,以便快速查找。
  • BFS初始化:从 beginWord 开始,加入队列,并记录为已访问。
  • BFS遍历:在每一步中,生成所有可能的变换单词(每个字母都可以变成其他25个字母),并检查这些变换是否在字典中且未被访问过。如果是,将它们加入队列。
  • 记录路径:当找到 endWord 时,记录路径并继续搜索,直到队列为空,确保找到所有可能的最短路径。
  • 解决代码

    #include 
    #include
    #include
    #include
    using namespace std;vector
    > findLadders(string beginWord, string endWord, vector
    wordList) { int n = beginWord.size(); // 检查所有单词长度是否一致 for (const string& word : wordList) { if (word.size() != n) { return {}; } } unordered_map
    wordId; for (int i = 0; i < wordList.size(); ++i) { wordId[wordList[i]] = i; } // 检查beginWord和endWord是否在字典中 if (wordId.find(beginWord) == wordId.end() || wordId.find(endWord) == wordId.end()) { return {}; } queue
    > q; unordered_set
    visited; vector
    > result; q.push({beginWord, 0}); visited.insert(beginWord); while (!q.empty()) { auto current = q.front(); q.pop(); string currentWord = current.first; int steps = current.second; if (currentWord == endWord) { result.push_back({currentWord}); continue; // 继续搜索可能的其他路径 } for (int i = 0; i < currentWord.size(); ++i) { char c = currentWord[i]; for (char ch = 'a'; ch <= 'z'; ++ch) { if (ch == c) continue; string newWord = currentWord; newWord[i] = ch; // 检查新单词是否在字典中且未被访问过 if (wordId.find(newWord) != wordId.end() && !visited.count(newWord)) { visited.insert(newWord); q.push({newWord, steps + 1}); } } } } return result;}

    代码解释

  • 预处理:检查所有单词的长度是否一致,确保转换过程中的单词长度保持一致。
  • 字典映射:使用 unordered_map 记录每个单词的位置,以便快速查找。
  • BFS初始化:从 beginWord 开始,初始化队列和已访问集合。
  • BFS遍历:生成所有可能的变换单词,检查是否在字典中,未被访问过,并加入队列。
  • 路径记录:每当找到 endWord 时,记录路径并继续搜索,确保找到所有可能的最短路径。
  • 这样,BFS算法能够高效地找到所有最短转换序列,确保中间单词都在字典中。

    转载地址:http://rcnpz.baihongyu.com/

    你可能感兴趣的文章
    PHP相关代码
    查看>>
    RabbitMQ
    查看>>
    php知识点记录
    查看>>
    PHP知识笔记:CGI, FastCGI, PHP-CGI, PHP-FPM, Spawn-FCGI区别
    查看>>
    PHP第三方登录—OAuth2.0协议
    查看>>
    php筛选js,php如何多条件筛选js代码
    查看>>
    R730服务器做了raid的硬盘,插在R720上面可以用吗?
    查看>>
    PHP类数组式访问(ArrayAccess接口)
    查看>>
    PHP系列:浅谈PHP中isset()和empty() 函数的区别
    查看>>
    PHP索引数组unset的坑-array_values解决方案
    查看>>
    PHP索引数组排序方法整理(冒泡、选择、插入、快速)
    查看>>
    PHP线程安全和非线程安全
    查看>>
    R3LIVE开源项目常见问题解决方案
    查看>>
    php缃戠珯,www.wfzwz.com
    查看>>
    php缓存查询函数
    查看>>
    php编写TCP服务端和客户端程序
    查看>>
    php编码规范
    查看>>
    PHP编码规范-PSR1、psr2 /psr3 psr4
    查看>>
    PHP编程效率的20个要点
    查看>>
    PHP网页缓存技术优点及代码
    查看>>