Word Ladder II leetcode java
题目:
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.
题解:
答案是http://www.1point3acres.com/bbs/thread-51646-1-1.html 上面
iostreamin写的。
我就直接贴过来就好,这道题多读读代码看明白。
代码:
1 public ArrayList<ArrayList<String>> findLadders(String start, String end, HashSet<String> dict) {
2
3 HashMap<String, HashSet<String>> neighbours = new HashMap<String, HashSet<String>>();
4
5 dict.add(start);
6 dict.add(end);
7
8 // init adjacent graph
9 for(String str : dict){
10 calcNeighbours(neighbours, str, dict);
11 }
12
13 ArrayList<ArrayList<String>> result = new ArrayList<ArrayList<String>>();
14
15 // BFS search queue
16 LinkedList<Node> queue = new LinkedList<Node>();
17 queue.add(new Node(null, start, 1)); //the root has not parent and its level == 1
18
19 // BFS level
20 int previousLevel = 0;
21
22 // mark which nodes have been visited, to break infinite loop
23 HashMap<String, Integer> visited = new HashMap<String, Integer>();
24 while(!queue.isEmpty()){
25 Node n = queue.pollFirst();
26 if(end.equals(n.str)){
27 // fine one path, check its length, if longer than previous path it's valid
28 // otherwise all possible short path have been found, should stop
29 if(previousLevel == 0 || n.level == previousLevel){
30 previousLevel = n.level;
31 findPath(n, result);
32 }else {
33 // all path with length *previousLevel* have been found
34 break;
35 }
36 }else {
37 HashSet<String> set = neighbours.get(n.str);
38
39 if(set == null || set.isEmpty()) continue;
40 // note: I'm not using simple for(String s: set) here. This is to avoid hashset's
41 // current modification exception.
42 ArrayList<String> toRemove = new ArrayList<String>();
43 for (String s : set) {
44
45 // if s has been visited before at a smaller level, there is already a shorter
46 // path from start to s thus we should ignore s so as to break infinite loop; if
47 // on the same level, we still need to put it into queue.
48 if(visited.containsKey(s)){
49 Integer occurLevel = visited.get(s);
50 if(n.level+1 > occurLevel){
51 neighbours.get(s).remove(n.str);
52 toRemove.add(s);
53 continue;
54 }
55 }
56 visited.put(s, n.level+1);
57 queue.add(new Node(n, s, n.level + 1));
58 if(neighbours.containsKey(s))
59 neighbours.get(s).remove(n.str);
60 }
61 for(String s: toRemove){
62 set.remove(s);
63 }
64 }
65 }
66
67 return result;
68 }
69
70 public void findPath(Node n, ArrayList<ArrayList<String>> result){
71 ArrayList<String> path = new ArrayList<String>();
72 Node p = n;
73 while(p != null){
74 path.add(0, p.str);
75 p = p.parent;
76 }
77 result.add(path);
78 }
79
80 /*
81 * complexity: O(26*str.length*dict.size)=O(L*N)
82 */
83 void calcNeighbours(HashMap<String, HashSet<String>> neighbours, String str, HashSet<String> dict) {
84 int length = str.length();
85 char [] chars = str.toCharArray();
86 for (int i = 0; i < length; i++) {
87
88 char old = chars[i];
89 for (char c = 'a'; c <= 'z'; c++) {
90
91 if (c == old) continue;
92 chars[i] = c;
93 String newstr = new String(chars);
94
95 if (dict.contains(newstr)) {
96 HashSet<String> set = neighbours.get(str);
97 if (set != null) {
98 set.add(newstr);
99 } else {
HashSet<String> newset = new HashSet<String>();
newset.add(newstr);
neighbours.put(str, newset);
}
}
}
chars[i] = old;
}
}
private class Node {
public Node parent; //previous node
public String str;
public int level;
public Node(Node p, String s, int l){
parent = p;
str = s;
level = l;
}
}
Reference:http://www.1point3acres.com/bbs/thread-51646-1-1.html
Word Ladder II leetcode java的更多相关文章
- Word Break II leetcode java
题目: Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where e ...
- Word Ladder II [leetcode]
本题有几个注意点: 1. 回溯找路径时.依据路径的最大长度控制回溯深度 2. BFS时,在找到end单词后,给当前层做标记find=true,遍历完当前层后结束.不须要遍历下一层了. 3. 能够将字典 ...
- [leetcode]Word Ladder II @ Python
[leetcode]Word Ladder II @ Python 原题地址:http://oj.leetcode.com/problems/word-ladder-ii/ 参考文献:http://b ...
- LeetCode: Word Ladder II 解题报告
Word Ladder II Given two words (start and end), and a dictionary, find all shortest transformation s ...
- [Leetcode Week5]Word Ladder II
Word Ladder II 题解 原创文章,拒绝转载 题目来源:https://leetcode.com/problems/word-ladder-ii/description/ Descripti ...
- 【leetcode】Word Ladder II
Word Ladder II Given two words (start and end), and a dictionary, find all shortest transformation ...
- LeetCode :Word Ladder II My Solution
Word Ladder II Total Accepted: 11755 Total Submissions: 102776My Submissions Given two words (start ...
- leetcode 127. Word Ladder、126. Word Ladder II
127. Word Ladder 这道题使用bfs来解决,每次将满足要求的变换单词加入队列中. wordSet用来记录当前词典中的单词,做一个单词变换生成一个新单词,都需要判断这个单词是否在词典中,不 ...
- 126. Word Ladder II(hard)
126. Word Ladder II 题目 Given two words (beginWord and endWord), and a dictionary's word list, find a ...
随机推荐
- python中的*和**参数传递机制
python的参数传递机制具有值传递(int.float等值数据类型)和引用传递(以字典.列表等非值对象数据类型为代表)两种基本机制以及方便的关键字传递特性(直接使用函数的形参名指定实参的传递目标,如 ...
- js原型鏈與js繼承解析
最近在網上看了諸多js原型鏈的解析,說得雲裡霧裡,不明所以.徹底了解後,決定出個博客記錄一下,一是方便後來人學習,二是方便日後複習. 首先,我們來看一下構造函數.原型.實例之間的關係圖: 所以,我們通 ...
- UVALive 6889 City Park 并查集
City Park 题目连接: http://acm.hust.edu.cn/vjudge/contest/view.action?cid=122283#problem/F Description P ...
- spring data jpa在使用PostgreSQL表名大小写的问题解决
国内的文章看了一遍,其实没找到根本问题解决方法,下面将列举这一系列的问题解决方法: 1.在配置文件增加如下配置: spring.jpa.hibernate.naming.physical-strate ...
- TCP状态知识总结(图解)
tcp状态: LISTEN:侦听来自远方的TCP端口的连接请求 SYN-SENT:再发送连接请求后等待匹配的连接请求 SYN-RECEIVED:再收到和发送一个连接请求后等待对方对连接请求的确认 ...
- Google 镜像站搜集
在特殊的地方和特殊的时间,流畅顺利的打开一个网站也变得如此艰难. 2016.01.16 更新.本站订阅更新功能已上线,欢迎订阅! 以下是直接使用谷歌的方法,如需***戳这里(VPN | Shadows ...
- AngularJS路由系列(3)-- UI-Router初体验
本系列探寻AngularJS的路由机制,在WebStorm下开发. AngularJS路由系列包括: 1.AngularJS路由系列(1)--基本路由配置2.AngularJS路由系列(2)--刷新. ...
- springboot static方法与构造方法加载@VALUE
application.properties文件 mongodb.host=host111 mongodb.port=port222 import org.springframework.beans. ...
- How can i use iptables on centos 7?
I installed CentOS 7 with minimal configuration (os + dev tools). I am trying to open 80 port for ht ...
- C#编程(六十二)---------LINQ标准的查询操作符
LINQ标准的查询操作符 首先我们来看一下LINQ的操作符,可根据查询操作符的操作”类型”进行分类,如把它们分成投影,限制,排序,联接,分组,串联,聚合,集合,生成,转换,元素,相等,量词,分割等. ...