leetcode - Word Ladder II
来源:互联网 发布:ios必备软件 编辑:程序博客网 时间:2024/06/07 19:02
Given two words (start and end), and a dictionary, find all shortest transformation sequence(s) from start to end, such that:
- Only one letter can be changed at a time
- Each intermediate word must exist in the dictionary
For example,
Given:
start = "hit"
end = "cog"
dict = ["hot","dot","dog","lot","log"]
Return
[ ["hit","hot","dot","dog","cog"], ["hit","hot","lot","log","cog"] ]
Note:
- All words have the same length.
- All words contain only lowercase alphabetic characters.
typedef std::pair<std::string,std::string> PAIR;void getSolution(std::string &end, std::string& word, std::unordered_multimap<std::string, std::string> &map, std::vector<std::vector<std::string> > &vec, std::vector<std::string> &vec2) {if(word == end || map.find(word) == map.end()) { if(word != end) return; vec2.push_back(end); vec.push_back(vec2); vec2.pop_back(); return;}std::pair<std::unordered_map<std::string, std::string>::iterator, std::unordered_map<std::string, std::string>::iterator> ret;ret = map.equal_range(word);while(ret.first != ret.second) { vec2.push_back(ret.first->first); getSolution(end, ret.first->second, map, vec, vec2); vec2.pop_back(); ret.first++;}}class Solution {public:std::vector<std::vector<std::string>> findLadders(std::string start, std::string end, std::unordered_set<std::string> &dict) {std::vector<std::vector<std::string>> vec; //if(start == end) { vec.push_back(vector<string>(1, start)); return vec; } std::unordered_multimap<std::string, std::string> edges; std::unordered_set<std::string> previousNodes; std::vector<std::unordered_set<std::string> > node_levels(2); int curLevel = 0; node_levels[curLevel].insert(end); std::unordered_set<std::string>::iterator it; while(!node_levels[curLevel].empty() && node_levels[curLevel].count(start) == 0) { for(it = node_levels[curLevel].begin(); it != node_levels[curLevel].end(); ++it) { for(size_t i = 0; i < it->size(); ++i) { std::string node(*it); for(node[i] = 'a'; node[i] <= 'z'; ++node[i]) { if(node == start) { node_levels[1-curLevel].insert(node); edges.insert(PAIR(start, *it)); break; } if(previousNodes.count(node) || node_levels[curLevel].count(node) || dict.count(node) == 0) continue; node_levels[1-curLevel].insert(node); edges.insert(PAIR(node, *it)); } } previousNodes.insert(*it); } node_levels[curLevel].clear(); curLevel = !curLevel; } previousNodes.clear(); if(node_levels[curLevel].empty()) return vec; std::vector<std::string> vec2; getSolution(end, start, edges, vec, vec2); return vec;}};
0 0
- 【leetcode】Word Ladder II
- [LeetCode]Word Ladder II
- [leetcode] Word Ladder II
- LeetCode - Word Ladder II
- Leetcode: Word Ladder II
- leetcode Word Ladder II
- Leetcode Word Ladder II
- LeetCode | Word Ladder II
- leetcode word ladder II
- 【Leetcode】Word Ladder II
- [LeetCode] Word Ladder II
- Word Ladder II -- LeetCode
- Leetcode: Word Ladder II
- leetcode-Word Ladder II
- leetcode-Word Ladder II
- leetcode: Word Ladder II
- leetcode Word Ladder II
- Leetcode: Word Ladder II
- memcache 集群
- Tizen源码下载
- 窗口上的【增加】【修改】【删除】【查询】【刷新】【查看】【退出】按钮的实现方法
- Tell me about yourself
- java版本号排序
- leetcode - Word Ladder II
- 高可用性、负载均衡的mysql集群解决方案
- Implement a simple iterator using javascript (node.js)
- Ubuntu 下创建用户后登录的时候一直停止登录界面
- Tomcat设置虚拟文件夹
- 跳棋jump
- 编程题
- mysql 学习笔记2
- 理解inode