-
Notifications
You must be signed in to change notification settings - Fork 0
/
Word_Break_II.java
30 lines (26 loc) · 1016 Bytes
/
Word_Break_II.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
class Solution {
public List<String> wordBreak(String s, List<String> wordDict) {
return wordBreakHelper(s, new HashSet<>(wordDict), new HashMap<>());
}
public List<String> wordBreakHelper(String s, Set<String> wordDict, Map<String, List<String>> memo) {
if (memo.containsKey(s)) {
return memo.get(s);
}
List<String> result = new ArrayList<>();
if (wordDict.contains(s)) {
result.add(s);
}
for (int i = 1; i < s.length(); i++) {
String prefix = s.substring(0, i);
if (wordDict.contains(prefix)) {
String suffix = s.substring(i);
List<String> suffixResult = wordBreakHelper(suffix, wordDict, memo);
for (String word : suffixResult) {
result.add(prefix + " " + word);
}
}
}
memo.put(s, result);
return result;
}
}