代码随想录第46天| 139.单词拆分 ,背包问题总结

LeetCode139.单词拆分 

题目链接:139. 单词拆分 - 力扣(LeetCode)

思路:

class Solution {
public:
    bool wordBreak(string s, vector& wordDict) {
        unordered_set wordset(wordDict.begin(), wordDict.end());
        vector 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);//substr(起始位置,截取的个数)
                if(wordset.find(word) != wordset.end() && dp[j]) {
                    dp[i] = true;
                }
            }
        }
        return dp[s.size()];
    }
};

你可能感兴趣的:(代码随想录,算法,leetcode,数据结构)