c_cpp 127.单词阶梯

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c_cpp 127.单词阶梯相关的知识,希望对你有一定的参考价值。

class Solution {
public:
    int ladderLength(string beginWord, string endWord, vector<string>& wordList) {
        unordered_set<string> dict(wordList.begin(), wordList.end());
        queue<string> Q;
        int res = 1;
        Q.push(beginWord);
        
        while (!Q.empty()) {
            int n = Q.size();
            for (int i = 0; i < n; i++) {
                string curStr = Q.front(); Q.pop();
                if (curStr == endWord) return res;
                for (int j = 0; j < curStr.size(); j++) {
                    string curStr_c = curStr;
                    for (int k = 0; k < 26; k++) {
                        curStr_c[j] = 'a' + k;
                        if (dict.count(curStr_c)) {
                            Q.push(curStr_c);
                            dict.erase(curStr_c);
                        }
                    }
                }
            }
            res++;
        }
        
        return 0;
    }
};

以上是关于c_cpp 127.单词阶梯的主要内容,如果未能解决你的问题,请参考以下文章

我如何打印 BFS 路径本身而不是这个单词阶梯的路径长度?

c_cpp [最后一个单词长度]计算字符串中最后一个单词的长度#字符串处理

c_cpp 在一个句子中找到最长的单词

c_cpp 计算字符串中的单词

c_cpp 计算字符串中的单词(C ++)

c_cpp 从一串单词中删除所有重复的单词。不只是重复,而是需要删除重复项的所有实例。