class Solution {
public:
int ladderLength(string start, string end, unordered_set<string> &dict) {
// Start typing your C/C++ solution below
// DO NOT write int main() function
//BFS(because all edge is 1) to find the minimum path
//O(n*len*26)
//shortest path O(n^2) will be TLE
queue<pair<string,int>> q;
unordered_set<string> visited;
q.push(make_pair(start, 1));
visited.insert(start);
while (!q.empty())
{
string curStr = q.front().first;
int curStep = q.front().second;
q.pop();
for (int i = 0; i < curStr.size(); ++i)
{
string tmp = curStr;
for (int j = 0; j < 26; ++j)
{
tmp[i] = j+'a';
if(tmp == end)
return curStep+1;
if(visited.find(tmp) == visited.end() && dict.find(tmp) != dict.end())
{
q.push(make_pair(tmp, curStep+1));
visited.insert(tmp);
}
}
}
}
return 0;
}
};[LeetCode]Word Ladder
最新推荐文章于 2018-06-12 10:14:22 发布
本文介绍了一种使用C++实现的广度优先搜索(BFS)算法来解决单词梯问题的方法。通过队列和哈希集合实现了对图中从起点到终点最短路径的有效搜索。算法的时间复杂度为O(n*len*26),适用于所有边权为1的情况。
2315

被折叠的 条评论
为什么被折叠?



