代码随想录算法训练营第四十九天|139.单词拆分

代码随想录算法训练营第四十九天|139.单词拆分

  • 139.单词拆分

139.单词拆分

题目链接:139.单词拆分
文章链接
状态:没思路看的视频

思路:dp[i] : 字符串长度为i的话,dp[i]为true,表示可以拆分为一个或多个在字典中出现的单词
如果求组合数就是外层for循环遍历物品,内层for遍历背包。

如果求排列数就是外层for遍历背包,内层for循环遍历物品。

代码

class Solution {
public:
    bool wordBreak(string s, vector<string>& wordDict) {
        unordered_set<string> wordSet(wordDict.begin(), wordDict.end());
        vector<bool> dp(s.size() + 1, false);
        dp[0] = true;
        for (int i = 1; i <= s.size(); i++) {  
            for (int j = 0; j < i; j++) {       
                string word = s.substr(j, i - j);
                if (wordSet.find(word) != wordSet.end() && dp[j]) {
                    dp[i] = true;
                }
            }
        }
        return dp[s.size()];
    }
};

你可能感兴趣的:(算法)