题目链接:单词拆分

给你一个字符串 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()];
    }
};

标签: hot100, Medium, 动态规划

添加新评论