动态规划——01背包问题、完全背包(python、一维DP)

01-背包问题:从最大容量开始,从后往前遍历背包容量

每种物品只能选择一次。物品种类为n,背包容量为k。从最大容量开始,从后往前遍历背包容量,小于当前物品容量的背包大小不遍历,即遍历到w[i]即可。

(1)容量不超过k时,最大价值为多少

dp数组初始化:dp=[0]*(k+1) ,全部初始化为0,表示都可达

复制代码
dp=[0]*(k+1)
for i in range():
    for j in range(k,w[i]-1,-1):
        dp[j]=max(dp[j],dp[j-w[i]]+val[i])
return dp[k]

(2)容量恰好为k时,最大价值为多少,如果不能恰好为k,则表示不可达,不可行

dp初始化:dp=[float('-inf')],初始化为负无穷大,表示为不可达

dp[0]=0 容量为0时,一定可达

复制代码
dp=[float('-inf')]*(k+1)
for i in range():
    for j in range(k,w[i]-1,-1):
        dp[j]=max(dp[j],dp[j-w[i]]+val[i])
if dp[k]==float('-inf'):
    print(0)
    return 0
else:
    print(dp[k])
    return dp[k]

完全背包问题:从前往后遍历背包容量

每种物品可以选择无限多次。物品种类为n种。

复制代码
dp=[0]*(k+1)
for i in range(n):
    for j in range(w[i],k+1):
        dp[j]=max(dp[j],dp[j-w[i]]+val[i])
return dp[k]
相关推荐
样例过了就是过了2 天前
LeetCode热题100 爬楼梯
c++·算法·leetcode·动态规划
样例过了就是过了2 天前
LeetCode热题100 跳跃游戏
c++·算法·leetcode·贪心算法·动态规划
做怪小疯子2 天前
LeetCode刷题——15.动态规划模式
算法·leetcode·动态规划
WolfGang0073212 天前
代码随想录算法训练营 Day29 | 动态规划 part02
算法·动态规划
样例过了就是过了2 天前
LeetCode热题100 跳跃游戏 II
c++·算法·leetcode·贪心算法·动态规划
故事和你913 天前
洛谷-算法1-2-排序2
开发语言·数据结构·c++·算法·动态规划·图论
花月C3 天前
线性动态规划(Linear DP)
算法·动态规划·代理模式
WolfGang0073213 天前
代码随想录算法训练营 Day28 | 动态规划 part01
算法·动态规划
散峰而望3 天前
【基础算法】动态规划从入门到进阶:记忆化搜索、线性 DP、LIS/LCS 一网打尽
c++·后端·算法·github·深度优先·动态规划·代理模式