$$dp[j] \text{ is true} \quad \text{AND} \quad \text{s.substring}(j, i) \text{ in wordDict}$$
-
2.18
- 需要先确定 i,再确定 j,然后判断 0 到 j 是否存在,j 到 i 是否存在
-
2.4
- 为了判断整个字符串
s能否被拆分,我们把它拆解成:“能不能找到一个分割点j,使得前半部分s[0..j]能被拆分,且后半部分s[j..i]恰好在字典里?” - 切割的是目标字符串,而不是单词表的字符串,j 代表落脚点,i 代表右边界
- 为了判断整个字符串
-
12.4
- 笔记丢了,这是又补的
- 将LIst转换为set,方便查找复杂度为O1
- 0-j-i
- j不能等于i,不然取子串(i,i)为空,没意义
- 找到一个dp为true后直接跳出循环,找下一个i
class Solution {
public boolean wordBreak(String s, List<String> wordDict) {
Set<String> set = new HashSet<>(wordDict);
boolean[] dp = new boolean[s.length()+1];
dp[0] = true;
for(int i=0;i<s.length()+1;i++){
for(int j=0;j<i;j++){
if(dp[j]&&set.contains(s.substring(j,i))){
dp[i]=true;
break;
}
}
}
return dp[s.length()];
}
}