D40|单词拆分+多重背包

139.单词拆分

给你一个字符串 s 和一个字符串列表 wordDict 作为字典。请你判断是否可以利用字典中出现的单词拼接出 s 。

注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用

输入: s = "leetcode", wordDict = ["leet", "code"]
输出: true
解释: 返回 true 因为 "leetcode" 可以由 "leet" 和 "code" 拼接成

题解复盘:

动态规划五部曲:

1)dp数组的含义(确实难想

        dp[i] : 字符串长度为i的话,dp[i]为true,表示可以拆分为一个或多个在字典中出现的单词

2)确定递推公式

如果确定dp[j] 是true,且 [j, i] 这个区间的子串出现在字典里,那么dp[i]一定是true。(j < i )。

所以递推公式是 if([j, i] 这个区间的子串出现在字典里 && dp[j]是true) 那么 dp[i] = true

3)dp数组如何初始化

 dp[i] 的状态依靠 dp[j]是否为true,那么dp[0]就是递推的根基,dp[0]一定要为true,否则递推下去后面都都是false了。

4)确定遍历顺序 

"apple", "pen" 是物品,那么我们要求 物品的组合一定是 "apple" + "pen" + "apple" 才能组成 "applepenapple"。

"apple" + "apple" + "pen" 或者 "pen" + "apple" + "apple" 是不可以的,那么我们就是强调物品之间顺序。

也就是求排列数

如果求组合数就是外层for循环遍历物品,内层for遍历背包

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

所以说,本题一定是 先遍历 背包,再遍历物品。

5)举例推导dp[i]

   

class Solution {
    public boolean wordBreak(String s, List<String> wordDict) {
        HashSet<String> set = new HashSet<>(wordDict);
        boolean[] valid = new boolean[s.length() + 1];
        valid[0] = true;

        for (int i = 1; i <= s.length(); i++) {
            for (int j = 0; j < i && !valid[i]; j++) {
                if (set.contains(s.substring(j, i)) && valid[j]) {
                    valid[i] = true;
                }
            }
        }

        return valid[s.length()];
    }
}

 这个版本的题解是和dp分析最符合的。


多重背包:

每个物品可使用n次,将其转换为01问题即可。

背包最大重量为10。

物品为:

重量 价值 数量
物品0 1 15 2
物品1 3 20 3
物品2 4 30 2

问背包能背的物品最大价值是多少?

和如下情况有区别么?

重量 价值 数量
物品0 1 15 1
物品0 1 15 1
物品1 3 20 1
物品1 3 20 1
物品1 3 20 1
物品2 4 30 1
物品2 4 30 1

毫无区别,这就转成了一个01背包问题了,且每个物品只用一次

最近更新

  1. TCP协议是安全的吗?

    2023-12-24 07:28:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-24 07:28:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-24 07:28:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-24 07:28:04       18 阅读

热门阅读

  1. Crow:Middlewares 庖丁解牛5 context

    2023-12-24 07:28:04       45 阅读
  2. css@media媒体查询

    2023-12-24 07:28:04       45 阅读
  3. [字符编码]windwos下使用libiconv转换编码格式(二)

    2023-12-24 07:28:04       47 阅读
  4. Pytorch项目,肺癌检测项目之三

    2023-12-24 07:28:04       39 阅读
  5. 力扣labuladong一刷day45天二分图判定

    2023-12-24 07:28:04       42 阅读
  6. 二级指针使用

    2023-12-24 07:28:04       42 阅读
  7. mybatisx 插件模板

    2023-12-24 07:28:04       42 阅读
  8. 第6章 用户输入和while循环

    2023-12-24 07:28:04       41 阅读
  9. Hadoop

    Hadoop

    2023-12-24 07:28:04      39 阅读