题目
给定一个非空字符串 s 和一个包含非空单词的列表 wordDict,判定 s 是否可以被空格拆分为一个或多个在字典中出现的单词。
1.拆分时可以重复使用字典中的单词。
2.你可以假设字典中没有重复的单词。
题解 动态规划
可以利用动态规划解决问题,dp[i]
表示从第一个位置到第i个位置是否可以被字典中的单词组成,即转移方程dp[j] && Check(j, i - j)
,所以可以建立一个Set容器方便查找。
class Solution {
public:
bool wordBreak(string s, vector<string>& wordDict) {
unordered_set<string> wordDictSet;
for(auto s : wordDict){
wordDictSet.insert(s);
}
int len = s.size();
vector<bool> dp(len + 1, false);
dp[0] = true;
for(int i = 1; i <= len; ++i){
for(int j = 0; j < i; ++j){
if(dp[j] && wordDictSet.find(s.substr(j, i - j)) != wordDictSet.end()){
dp[i] = true;
break;
}
}
}
return dp[len];
}
};