单词拆分
题目链接:单词拆分
给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。
注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。
方法一:动态规划
class Solution {
public:
bool wordBreak(string s, vector<string>& wordDict) {
vector<bool> dp(s.size()+1);
dp[0] = true;
for (int i = 1;i <= s.size();i++) {
for (auto& word:wordDict) {
int sz = word.size();
if (i - sz >= 0 && s.substr(i-sz,sz) == word)
dp[i] = dp[i] || dp[i-sz];
}
}
return dp[s.size()];
}
};