动态规划背包问题

44 篇文章 0 订阅
38 篇文章 0 订阅

一个包可以背4kg的东西,现在有四件东西,重量分别为1kg,4kg,3kg,1kg,价值为:1500,3000,2000,2000;

现在要求你,在包里背的东西价值最大,但是不能超过背包的最大载重量。

代码如下;

#几件物品的重量
w = [0,1,4,3,1]
#几件物品的价值
v= [0, 1500, 3000, 2000, 2000]
#物品数量
n = len(w) - 1
#包的载重量
m = 4

#建立一个列表表示在包中的物品,元素是True时代表对应元素放入
x = []   
#放入包中的总价值
value = 0
#建立一个矩阵,来表示在前i个物品中,当载重量是j时,放入包中的最大价值,table[i][j]
table = [[0 for i in range(m+1)] for j in range(n+1)]

def dynamic(w,v,n,m,x):
    #计算table矩阵
    for i in range(1, n+1):    #代表物品一件一件的考虑
        for j in range(1, m+1):     #代表子背包的大小一点一点的考虑
            if (j >= w[i]):    #当背包的大小大于物品的重量时,考虑放进去
                table[i][j] = max(table[i-1][j], table[i-1][j-w[i]] + v[i])
            else:
                table[i][j] = table[i -1][j]   #如果放不进去,就继承之前的价值
                
    #递推装入背包中的物体,寻找跳变的地方,从最后结果开始逆推
    j = m
    for i in range(n, 0, -1):
        if table[i][j] > table[i- 1][j]:   #如果多加一件物品之后,价值增大,就将这一件物品加入列表中
            x.append(i)
            j = j - w[i]    #此时为剩余背包的载重量
            
    #返回最大价值,即表格中最后一行最后一列的值
    value = table[n][m]
    return value

print("最大价值为:", str(dynamic(w, v, n, m, x)))
print("物品的索引:", x)
      

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值