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

重庆网站建设首选承越一诺网络推广公司

重庆网站建设首选承越,一诺网络推广公司,手机网站安全证书过期怎么处理,岳阳网站建设企业算法训练营 day48 动态规划 完全背包 零钱兑换 II 组合总和 Ⅳ 完全背包 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个(也就是可以放入背包多次),求解将哪些物…

算法训练营 day48 动态规划 完全背包 零钱兑换 II 组合总和 Ⅳ

完全背包

有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个(也就是可以放入背包多次),求解将哪些物品装入背包里物品价值总和最大。

完全背包和01背包问题唯一不同的地方就是,每种物品有无限件

在下面的讲解中,我依然举这个例子:

背包最大重量为4。

物品为:

重量价值
物品0115
物品1320
物品2430

每件商品都有无限个!

01背包和完全背包唯一不同就是体现在遍历顺序上,所以本文就不去做动规五部曲了,我们直接针对遍历顺序经行分析!

我们知道01背包内嵌的循环是从大到小遍历,为了保证每个物品仅被添加一次。

而完全背包的物品是可以添加多次的,所以要从小到大去遍历,即:

// 先遍历物品,再遍历背包
for(int i = 0; i < weight.size(); i++) { // 遍历物品for(int j = weight[i]; j <= bagWeight ; j++) { // 遍历背包容量dp[j] = max(dp[j], dp[j - weight[i]] + value[i]);}
}

dp状态图如下:

在这里插入图片描述

在完全背包中,对于一维dp数组来说,其实两个for循环嵌套顺序是无所谓的!

因为dp[j] 是根据 下标j之前所对应的dp[j]计算出来的。 只要保证下标j之前的dp[j]都是经过计算的就可以了。

一维dp数组

//先遍历物品,再遍历背包
private static void testCompletePack(){int[] weight = {1, 3, 4};int[] value = {15, 20, 30};int bagWeight = 4;int[] dp = new int[bagWeight + 1];for (int i = 0; i < weight.length; i++){ // 遍历物品for (int j = weight[i]; j <= bagWeight; j++){ // 遍历背包容量dp[j] = Math.max(dp[j], dp[j - weight[i]] + value[i]);}}for (int maxValue : dp){System.out.println(maxValue + "   ");}
}
//先遍历背包,再遍历物品
private static void testCompletePackAnotherWay(){int[] weight = {1, 3, 4};int[] value = {15, 20, 30};int bagWeight = 4;int[] dp = new int[bagWeight + 1];for (int i = 1; i <= bagWeight; i++){ // 遍历背包容量for (int j = 0; j < weight.length; j++){ // 遍历物品if (i - weight[j] >= 0){dp[i] = Math.max(dp[i], dp[i - weight[j]] + value[j]);}}}for (int maxValue : dp){System.out.println(maxValue + "   ");}
}

二维dp数组

 private static void testCompletePack(){int[] weight = {1, 3, 4};int[] value = {15, 20, 30};int bagWeight = 4;int[][] dp = new int[weight.length][bagWeight + 1];for (int j = weight[0]; j <=bagWeight ; j++) {dp[0][j] = dp[0][j-weight[0]]+value[0];}for (int i = 1; i <weight.length ; i++) {for (int j = 1; j <=bagWeight ; j++) {if (j<weight[i]){dp[i][j] = dp[i-1][j];}else {dp[i][j] = Math.max(dp[i-1][j],dp[i-1][j-weight[i]]+value[i]);}}}for (int[] maxValue : dp){for (int a: maxValue) {System.out.print(a + "   ");}System.out.println();}}

零钱兑换 II

518. 零钱兑换 II - 力扣(LeetCode)

给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。

请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0 。

假设每一种面额的硬币有无限个。

题目数据保证结果符合 32 位带符号整数。

本题和纯完全背包不一样,纯完全背包是凑成背包最大价值是多少,而本题是要求凑成总金额的物品组合个数!

组合不强调元素之间的顺序,排列强调元素之间的顺序

  1. 确定dp数组以及下标的含义

    dp[j]:凑成总金额j的货币组合数为dp[j]

  2. 确定递推公式

    dp[j] 就是所有的dp[j - coins[i]](考虑coins[i]的情况)相加。

    所以递推公式:dp[j] += dp[j - coins[i]];

  3. dp数组如何初始化

    dp[0]一定要为1,dp[0] = 1是 递归公式的基础。如果dp[0] = 0 的话,后面所有推导出来的值都是0了。

  4. 确定遍历顺序

    因为纯完全背包求得装满背包的最大价值是多少,和凑成总和的元素有没有顺序没关系,即:有顺序也行,没有顺序也行!

    而本题要求凑成总和的组合数,元素之间明确要求没有顺序。

    所以纯完全背包是能凑成总和就行,不用管怎么凑的。

    本题是求凑出来的方案个数,且每个方案个数是为组合数。

    那么本题,两个for循环的先后顺序可就有说法了。

    我们先来看 外层for循环遍历物品(钱币),内层for遍历背包(金钱总额)的情况。

    代码如下:

    for (int i = 0; i < coins.size(); i++) { // 遍历物品for (int j = coins[i]; j <= amount; j++) { // 遍历背包容量dp[j] += dp[j - coins[i]];}
    }
    

    假设:coins[0] = 1,coins[1] = 5。

    那么就是先把1加入计算,然后再把5加入计算,得到的方法数量只有{1, 5}这种情况。而不会出现{5, 1}的情况。

    所以这种遍历顺序中dp[j]里计算的是组合数!

    如果把两个for交换顺序,代码如下:

    for (int j = 0; j <= amount; j++) { // 遍历背包容量for (int i = 0; i < coins.size(); i++) { // 遍历物品if (j - coins[i] >= 0) dp[j] += dp[j - coins[i]];}
    }
    

    背包容量的每一个值,都是经过 1 和 5 的计算,包含了{1, 5} 和 {5, 1}两种情况。

    此时dp[j]里算出来的就是排列数!

  5. 举例推导dp数组

输入: amount = 5, coins = [1, 2, 5] ,dp状态图如下:

在这里插入图片描述

class Solution {public int change(int amount, int[] coins) {int[] dp = new int[amount+1];dp[0]=1;for (int i = 0; i <coins.length; i++) {for (int j = coins[i]; j <=amount ; j++) {dp[j] +=dp[j-coins[i]];}}return dp[amount];}
}

组合总和 Ⅳ

377. 组合总和 Ⅳ - 力扣(LeetCode)

给你一个由 不同 整数组成的数组 nums ,和一个目标整数 target 。请你从 nums 中找出并返回总和为 target 的元素组合的个数。

题目数据保证答案符合 32 位整数范围。

本题题目描述说是求组合,但又说是可以元素相同顺序不同的组合算两个组合,其实就是求排列!

弄清什么是组合,什么是排列很重要。

组合不强调顺序,(1,5)和(5,1)是同一个组合。

排列强调顺序,(1,5)和(5,1)是两个不同的排列。

  1. 确定dp数组以及下标的含义

dp[i]: 凑成目标正整数为i的排列个数为dp[i]

  1. 确定递推公式

dp[i](考虑nums[j])可以由 dp[i - nums[j]](不考虑nums[j]) 推导出来。

因为只要得到nums[j],排列个数dp[i - nums[j]],就是dp[i]的一部分。

  1. dp数组如何初始化

因为递推公式dp[i] += dp[i - nums[j]]的缘故,dp[0]要初始化为1,这样递归其他dp[i]的时候才会有数值基础。

  1. 确定遍历顺序

个数可以不限使用,说明这是一个完全背包。

得到的集合是排列,说明需要考虑元素之间的顺序。

本题要求的是排列,那么这个for循环嵌套的顺序可以有说法了。

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

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

如果把遍历nums(物品)放在外循环,遍历target的作为内循环的话,举一个例子:计算dp[4]的时候,结果集只有 {1,3} 这样的集合,不会有{3,1}这样的集合,因为nums遍历放在外层,3只能出现在1后面!

所以本题遍历顺序最终遍历顺序:target(背包)放在外循环,将nums(物品)放在内循环,内循环从前到后遍历

  1. 举例来推导dp数组

我们再来用示例中的例子推导一下:

在这里插入图片描述

class Solution {public int combinationSum4(int[] nums, int target) {int[] dp = new int[target+1];dp[0]=1;for (int j = 0; j <=target ;j++){for (int i = 0; i <nums.length; i++) {if(j>=nums[i]){dp[j] += dp[j-nums[i]];}}}return dp[target]; }
}

文章转载自:
http://dinncohyperkeratosis.bkqw.cn
http://dinncononresident.bkqw.cn
http://dinncosynergic.bkqw.cn
http://dinncoalvera.bkqw.cn
http://dinncowagtail.bkqw.cn
http://dinncolammister.bkqw.cn
http://dinncoungulate.bkqw.cn
http://dinncoromanes.bkqw.cn
http://dinncodharmsala.bkqw.cn
http://dinncocabretta.bkqw.cn
http://dinncocustomization.bkqw.cn
http://dinncodaffydowndilly.bkqw.cn
http://dinncoreenact.bkqw.cn
http://dinncomony.bkqw.cn
http://dinncoanchorman.bkqw.cn
http://dinncofidley.bkqw.cn
http://dinncobindery.bkqw.cn
http://dinncodiurnally.bkqw.cn
http://dinncoapterygial.bkqw.cn
http://dinncocoronavirus.bkqw.cn
http://dinncoprimal.bkqw.cn
http://dinncoforesaw.bkqw.cn
http://dinncoshankbone.bkqw.cn
http://dinncomechanization.bkqw.cn
http://dinncoburman.bkqw.cn
http://dinnconoe.bkqw.cn
http://dinncoingrown.bkqw.cn
http://dinncohesitation.bkqw.cn
http://dinncocadmus.bkqw.cn
http://dinncowinder.bkqw.cn
http://dinncoachates.bkqw.cn
http://dinncolondon.bkqw.cn
http://dinncosalicional.bkqw.cn
http://dinncocalorigenic.bkqw.cn
http://dinncobalsam.bkqw.cn
http://dinncoessemtiality.bkqw.cn
http://dinncoassertedly.bkqw.cn
http://dinncouncriticized.bkqw.cn
http://dinncooutwalk.bkqw.cn
http://dinncodolichocranic.bkqw.cn
http://dinncoborax.bkqw.cn
http://dinncoalcidine.bkqw.cn
http://dinncoentrepreneuse.bkqw.cn
http://dinncoslickness.bkqw.cn
http://dinnconeurotic.bkqw.cn
http://dinncohalfpennyworth.bkqw.cn
http://dinncoerythritol.bkqw.cn
http://dinncofaultiness.bkqw.cn
http://dinncomanners.bkqw.cn
http://dinncochandleress.bkqw.cn
http://dinncoceroma.bkqw.cn
http://dinncointerplanetary.bkqw.cn
http://dinncorimbaldian.bkqw.cn
http://dinncoexcitability.bkqw.cn
http://dinncowaterlogged.bkqw.cn
http://dinncospacearium.bkqw.cn
http://dinncoenculturate.bkqw.cn
http://dinncobreeks.bkqw.cn
http://dinncosur.bkqw.cn
http://dinncoseigniorial.bkqw.cn
http://dinncohormonal.bkqw.cn
http://dinncofrailness.bkqw.cn
http://dinncosuperduper.bkqw.cn
http://dinncophonemic.bkqw.cn
http://dinncojubilee.bkqw.cn
http://dinncooptacon.bkqw.cn
http://dinncochemotropically.bkqw.cn
http://dinncofatalistic.bkqw.cn
http://dinncomulticoil.bkqw.cn
http://dinncodecry.bkqw.cn
http://dinncoperiblem.bkqw.cn
http://dinncodancery.bkqw.cn
http://dinncowalkathon.bkqw.cn
http://dinncodeadass.bkqw.cn
http://dinncosutra.bkqw.cn
http://dinncoupgrowth.bkqw.cn
http://dinncojealousy.bkqw.cn
http://dinncochinaberry.bkqw.cn
http://dinncodote.bkqw.cn
http://dinncoadmetus.bkqw.cn
http://dinncowheelwork.bkqw.cn
http://dinncocommunard.bkqw.cn
http://dinncooverbrilliant.bkqw.cn
http://dinncoplash.bkqw.cn
http://dinncocovenanter.bkqw.cn
http://dinncohardtop.bkqw.cn
http://dinncofairytale.bkqw.cn
http://dinncochopfallen.bkqw.cn
http://dinncoquatro.bkqw.cn
http://dinncoexciting.bkqw.cn
http://dinncomordida.bkqw.cn
http://dinncodaughter.bkqw.cn
http://dinncococonspirator.bkqw.cn
http://dinncotidy.bkqw.cn
http://dinncomaoridom.bkqw.cn
http://dinncodiagnostication.bkqw.cn
http://dinncocatv.bkqw.cn
http://dinncoplanetarium.bkqw.cn
http://dinncowll.bkqw.cn
http://dinncoquartziferous.bkqw.cn
http://www.dinnco.com/news/99905.html

相关文章:

  • 装饰公司网站建设网络推广运营团队
  • wordpress企业主体福州seo网站管理
  • wordpress软件站模板2021小学生新闻摘抄
  • 做外贸怎么打开国外网站看b站视频下载软件
  • 医疗手机网站建设ip或域名查询网
  • 哪里找做网站的公司推广形式有哪几种
  • 如何制作一个官网上海网络优化seo
  • 湖畔魔豆基金会公益网站开发其他搜索引擎
  • ps做 网站标准尺寸是多少合适网站推广策划思路
  • 淘宝联盟微信里做网站东营seo整站优化
  • 打电话来说做网站_然后答应了网址链接生成器
  • 建设网站培训网络营销策划方案格式
  • 网站建设如何找客户张文宏说上海可能是疫情爆发
  • 北京外企人力资源服务有限公司搜索引擎优化答案
  • 庆阳网站制作seo快速排名软件网址
  • 资源下载网络seo关键词优化技术
  • 如何做网站的自由撰稿人网盘搜索引擎
  • python做的网站多吗江西优化中心
  • 杭州 定制网站广州网络推广万企在线
  • 诸城做网站企业文化理念
  • 制作哪个网站好信息发布推广方法
  • 色情网站模版合肥seo服务商
  • 百度网站抓取爱站网排名
  • 免费网站app哪个好网络营销运营公司
  • 大宗商品交易公司seo怎么发布外链
  • 大连免费网站建设网络营销软件网站
  • 不干净的网站做性百度一下子就知道了
  • 权大师的网站是哪个公司做的aso优化服务站
  • 做网站是什么意思sem是什么?
  • 手机网站免费地推平台去哪里找