代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)

52.携带研究材料(卡码网)

题目链接

携带研究材料https://kamacoder.com/problempage.php?pid=1052

核心思路

1,确定dp数组及其下标含义

定义一个一维dp数组,下标表示背包大小。

2,确定递推公式

因为完全背包的物品是无限个,所以放完了一个,还能在同一层找。

二维递推公式写法:dp[ i ][ j ] = max(dp[ i - 1 ][ j ] , dp[ i ][ j - w[ i ] ] + v[ i ] )

一维递推公式写法:dp[ j ] = max(dp[ j ] , dp[ j - w[ i ] ] + v [ i ] )

4,初始化数组

全部为0

3,确定循环顺序

因为完全背包物品有无限个,所以遍历背包可以正序遍历,这样正好默认是在同一层

易错点

一维递推公式写法:dp[ j ] = max(dp[ j ] , dp[ j - w[ i ] ] + v [ i ] )

518.零钱兑换||

题目链接

零钱兑换||https://leetcode.cn/problems/coin-change-ii/description/

核心思路

1,定义一维dp数组,dp[ j ] 为填满背包大小为 j 的背包的组合数有dp [ j ]种。

2,确定递推公式

因为求的是方法有多少种,所以用累加的形式:

dp[ j ] = dp[ j ] + dp[ j - w[ i ] ];

表示填满当前背包有两种来源:

不放物品 i ,那么就是dp[ j ]。

放物品 i ,那么就是dp[ j - w[ i ] ]。

3,初始化dp数组

dp[0] = 1;

4,确定遍历方向

先遍历物品,再遍历背包。背包是正序遍历

易错点

1,背包大小要从w[ i ]开始,放不进就默认dp [ j ]

2,dp数组的类型为unsigned long long

377.组合总和IV

题目链接

组合总和IVhttps://leetcode.cn/problems/combination-sum-iv/description/

核心思路

1,定义一个一维dp数组,dp[ j ] 表示当背包为 j 时,排列数为多少个

2,确定递推公式dp[ j ] = dp[ j ] + dp[ j - w[ i ] ];

3,初始化dp数组

dp[ 0 ] = 0

4,确定遍历顺序

因为求的是排列数,对顺序有要求,那我们就考虑填满每个背包大小的最后一个值是什么。因为每个背包大小都要考虑,所以物品在内层循环。

易错点

1,dp数组的类型为unsigned long long

2,遍历顺序为,背包在外,物品在内

57.爬楼梯(卡码网)

题目链接

爬楼梯(卡码网)https://kamacoder.com/problempage.php?pid=1067

核心思路

1,确定一维dp数组及其下标含义

dp[ j ] 表示爬上台阶为 j 总共有 dp[ j ]种方法

2,推导递推公式dp[ j ] = dp[ j ] + dp[ j - w[ i ] ];

3,初始化数组

dp[0] = 0

4,确定遍历顺序

因为是排列数,所以物品放内,背包放外

易错点

1,台阶个数是背包大小,一次可以爬多少个台阶是物品。

2,初始化了台阶个数为0时的方法,所以背包从1开始

3,物品从1开始,小于等于m。

相关推荐
载数而行5201 天前
算法系列5之交换排序
c语言·数据结构·c++·算法·排序算法
重生之后端学习1 天前
35. 搜索插入位置
java·数据结构·算法·leetcode·职场和发展·深度优先
程序员南飞1 天前
算法笔试-求一个字符串的所有子串
java·开发语言·数据结构·python·算法·排序算法
陆嵩1 天前
从一个小例子实践代数多重网格方法
算法·amg·多重网格·粗化·插值算子·光滑·v cycle
清水白石0081 天前
模板方法模式全解析:用抽象基类定义算法骨架,让子类优雅填充细节
数据库·python·算法·模板方法模式
DeepModel1 天前
【分类算法】C4.5分类算法超详细讲解
算法·决策树·回归
努力学算法的蒟蒻1 天前
day96(2.25)——leetcode面试经典150
算法·leetcode·面试
吕司1 天前
LeetCode Hot Code——找到字符串中所有字母异位词
算法·leetcode
AI科技星1 天前
物理世界的几何建构:论统一场论的本体论革命与概念生成
人工智能·opencv·线性代数·算法·矩阵
让我上个超影吧1 天前
【力扣34】在排序数组中查找元素的第一个和最后一个位置
java·数据结构·算法·leetcode