当前位置: 首页 > news >正文

网站海报是怎么做的百度添加网站

网站海报是怎么做的,百度添加网站,海口网站制作,濉溪县最新通告今天算法训练营 day50 动态规划 单词拆分 多重背包理论基础 单词拆分 139. 单词拆分 - 力扣(LeetCode) 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。请你判断是否可以利用字典中出现的单词拼接出 s 。 注意:不要求字典中出现的单词…

算法训练营 day50 动态规划 单词拆分 多重背包理论基础

单词拆分

139. 单词拆分 - 力扣(LeetCode)

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

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

单词就是物品,字符串s就是背包,单词能否组成字符串s,就是问物品能不能把背包装满。

拆分时可以重复使用字典中的单词,说明就是一个完全背包!

  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. 确定遍历顺序

    题目中说是拆分为一个或多个在字典中出现的单词,所以这是完全背包。

    还要讨论两层for循环的前后顺序。

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

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

    而本题其实我们求的是排列数,为什么呢。 拿 s = “applepenapple”, wordDict = [“apple”, “pen”] 举例。“apple”, “pen” 是物品,那么我们要求 物品的组合一定是 “apple” + “pen” + “apple” 才能组成 “applepenapple”。

    “apple” + “apple” + “pen” 或者 “pen” + “apple” + “apple” 是不可以的,那么我们就是强调物品之间顺序。所以说,本题一定是 先遍历 背包,再遍历物品。

  5. 举例推导dp[i]

    以输入: s = “leetcode”, wordDict = [“leet”, “code”]为例,dp状态如图:

在这里插入图片描述

dp[s.size()]就是最终结果。

class Solution {public boolean wordBreak(String s, List<String> wordDict) {boolean[] dp = new boolean[s.length()+1];Arrays.fill(dp,false);dp[0] = true;HashSet<String> set = new HashSet<>(wordDict);for (int i = 1; i <=s.length(); i++) {for (int j = 0; j <i; j++) {if (set.contains(s.substring(j,i)) && dp[j]){dp[i] = true;}}}return dp[s.length()];}
}

多重背包理论基础

有N种物品和一个容量为V 的背包。第i种物品最多有Mi件可用,每件耗费的空间是Ci ,价值是Wi 。求解将哪些物品装入背包可使这些物品的耗费的空间 总和不超过背包容量,且价值总和最大。

多重背包和01背包是非常像的, 为什么和01背包像呢?

每件物品最多有Mi件可用,把Mi件摊开,其实就是一个01背包问题了。

例如:

背包最大重量为10。

物品为:

重量价值数量
物品01152
物品13203
物品24302

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

和如下情况有区别么?

重量价值数量
物品01151
物品01151
物品13201
物品13201
物品13201
物品24301
物品24301

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

改变物品数量为01背包格式

public void testMultiPack1(){// 版本一:改变物品数量为01背包格式List<Integer> weight = new ArrayList<>(Arrays.asList(1, 3, 4));List<Integer> value = new ArrayList<>(Arrays.asList(15, 20, 30));List<Integer> nums = new ArrayList<>(Arrays.asList(2, 3, 2));int bagWeight = 10;for (int i = 0; i < nums.size(); i++) {while (nums.get(i) > 1) { // 把物品展开为iweight.add(weight.get(i));value.add(value.get(i));nums.set(i, nums.get(i) - 1);}}int[] dp = new int[bagWeight + 1];for(int i = 0; i < weight.size(); i++) { // 遍历物品for(int j = bagWeight; j >= weight.get(i); j--) { // 遍历背包容量dp[j] = Math.max(dp[j], dp[j - weight.get(i)] + value.get(i));}System.out.println(Arrays.toString(dp));}
}

版本二:改变遍历个数

public void testMultiPack2(){// 版本二:改变遍历个数int[] weight = new int[] {1, 3, 4};int[] value = new int[] {15, 20, 30};int[] nums = new int[] {2, 3, 2};int bagWeight = 10;int[] dp = new int[bagWeight + 1];for(int i = 0; i < weight.length; i++) { // 遍历物品for(int j = bagWeight; j >= weight[i]; j--) { // 遍历背包容量// 以上为01背包,然后加一个遍历个数for (int k = 1; k <= nums[i] && (j - k * weight[i]) >= 0; k++) { // 遍历个数dp[j] = Math.max(dp[j], dp[j - k * weight[i]] + k * value[i]);}System.out.println(Arrays.toString(dp));}}
}
http://www.yayakq.cn/news/648763/

相关文章:

  • 手机网站推广服务个人微信公众号注册
  • 网站wap设置做八年级题目的网站
  • 免费在线响应式网站自助建站wordpress 微博 链接地址
  • 英文网站的首页怎么做wordpress制作的网页
  • 做微课的网站有哪些方面网站开发过程记录册
  • 凡科做的网站手机版wordpress4.9.4源码
  • 做p2p理财网站网络游戏营销策略
  • google网站收录入口网站结合微信
  • 江苏省建设厅网站 杨洪海新网站建设的工作总结
  • 如何在电影网站中做淘客莱芜金点子最新招聘信息招聘网
  • 短视频营销常用的平台有河南智能seo快速排名软件
  • 网站布局内容山东平台网站建设找哪家
  • 长沙城乡建设网站首页宁波网站建设-中国互联
  • 体育局网站建设方案网站后台管理进入
  • 仿造网站用侵权吗昆明网站设计公司哪家好
  • 微信网页宣传网站怎么做的北京市建筑信息平台
  • 做网站一屏的尺寸是宝塔建站wordpress
  • 网站常用的优化方法wordpress empty
  • 呼和浩特市网站公司电话什么网站 是cms系统下载地址
  • 有云服务器和域名怎么做网站石河子农八师建设兵团社保网站
  • 法华寺网站建设网站开发官网
  • 合肥公司做网站无锡高端网站建设哪家好
  • 德芙巧克力的软文500字WordPress优化手机端
  • 威海做网站的seo快排
  • 网站内页优化物联网平台是什么意思
  • 中国网络营销网站网页设计图片怎么插
  • 简单网站开发项目实例安徽建设工程信息网查询平台公司
  • 长春网站设计长春网络推广沪尚茗居和沪佳哪个好
  • 网站推广的具体方法网站运营工作是干什么的
  • 郑州专业的网站建设公司哪家好高校建设网站的特色