代码随想录二刷day44

您所在的位置:网站首页 for循环求总和 代码随想录二刷day44

代码随想录二刷day44

2023-07-09 02:59| 来源: 网络整理| 查看: 265

day44 完全背包基础知识问题描述举个栗子 518. 零钱兑换 II1.确定dp数组以及下标的含义2.确定递推公式3.dp数组如何初始化4.确定遍历顺序5.举例推导dp数组 377. 组合总和 Ⅳ1.确定dp数组以及下标的含义2.确定递推公式3.dp数组如何初始化4.确定遍历顺序5.举例来推导dp数组

完全背包基础知识 问题描述

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

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

举个栗子

背包最大重量为4。

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

完全背包的物品是可以添加多次的,所以要从小到大去遍历 在这里插入图片描述

// 先遍历物品,在遍历背包 void test_CompletePack() { vector weight = {1, 3, 4}; vector value = {15, 20, 30}; int bagWeight = 4; vector dp(bagWeight + 1, 0); for(int i = 0; i // 遍历背包容量 dp[j] = max(dp[j], dp[j - weight[i]] + value[i]); } } cout // 遍历物品 for (int j = coins[i]; j // 遍历背包容量 for (int i = 0; i public: int change(int amount, vector& coins) { vector dp(amount + 1, 0); dp[0] = 1; for (int i = 0; i // 遍历背包 dp[j] += dp[j - coins[i]]; } } return dp[amount]; } }; 377. 组合总和 Ⅳ

题目链接 解题思路:本题题目描述说是求组合,但又说是可以元素相同顺序不同的组合算两个组合,其实就是求排列。

动规五部曲分析如下:

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

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

2.确定递推公式

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

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

求装满背包有几种方法,递推公式一般都是dp[i] += dp[i - nums[j]];

本题也一样。

3.dp数组如何初始化

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

至于dp[0] = 1 有没有意义呢?

其实没有意义,所以我也不去强行解释它的意义了,因为题目中也说了:给定目标值是正整数! 所以dp[0] = 1是没有意义的,仅仅是为了推导递推公式。

至于非0下标的dp[i]应该初始为多少呢?

初始化为0,这样才不会影响dp[i]累加所有的dp[i - nums[j]]。

4.确定遍历顺序

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

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

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

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

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

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

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

5.举例来推导dp数组

我们再来用示例中的例子推导一下: 输入:nums =[1,2,3] , target = 4 在这里插入图片描述 C++代码如下:

class Solution { public: int combinationSum4(vector& nums, int target) { vector dp(target + 1, 0); dp[0] = 1; for (int i = 0; i // 遍历物品 if (i - nums[j] >= 0 && dp[i]


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3