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 从一串单词中删除所有重复的单词。不只是重复,而是需要删除重复项的所有实例。