Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each word is a valid dictionary word.
Return all such possible sentences.
For example, given
s = "catsanddog",
dict = ["cat", "cats", "and", "sand", "dog"].
A solution is ["cats and dog", "cat sand dog"].
这道题目是word break的变种,这里要求返回可能的组合,不是单纯的判断可不可以有dict种的元素组成。我们采用回溯法,类似N-queen中的循环递归所有可能的情况。代码如下:
Return all such possible sentences.
For example, given
s = "catsanddog",
dict = ["cat", "cats", "and", "sand", "dog"].
A solution is ["cats and dog", "cat sand dog"].
这道题目是word break的变种,这里要求返回可能的组合,不是单纯的判断可不可以有dict种的元素组成。我们采用回溯法,类似N-queen中的循环递归所有可能的情况。代码如下:
public class Solution {
public List<String> wordBreak(String s, Set<String> wordDict) {
List<String> list = new ArrayList<String>();
if(s == null || s.length() == 0) return list;
helper(0, "", s, wordDict, list);
return list;
}
private void helper(int start, String res, String s, Set<String> wordDict, List<String> list) {
if(start == s.length()) {
list.add(res);
}
for(int i = start; i < s.length(); i++) {
String tem = s.substring(start, i + 1);
if(wordDict.contains(tem)) {
String newS = res.length() > 0 ? res + " " + tem : tem;
helper(i + 1, newS, s, wordDict, list);
}
}
}
}
本文深入探讨了WordBreak算法的一种变种,即在字符串中加入空格形成有效句子的问题,并详细阐述了使用回溯法解决此问题的步骤和过程。通过实例代码展示了解题策略,旨在帮助读者理解复杂字符串操作背后的逻辑。
5184

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



