理解动态规划——01背包问题

本文详细探讨了动态规划中的经典问题——01背包问题,通过讲解其核心的最大化公式,结合具体实现步骤,揭示了解决这类问题的关键思路,并展示了最终的求解结果。
摘要由CSDN通过智能技术生成

1. 概述

01背包问题是很经典的动态规划问题。它的核心便是一个最大化公式


其中f(i, j)前面i个商品在背包容量为j的情况下达到的最大的价值;weight[i]是第i件商品的重量;prize[i]是商品的价值。也就是在现在这个背包大小情况下在选择还是不选择当前商品中求取总价值最大化。本文中使用较为经典的方式(使用中间表)来解决该问题。
这是本文中测试数据得到的中间表:

该表的创建顺序是:从上往下,从左往右创建的。表中0~10的数字代表的是背包的容量,背包容量在增长的过程中,最大化背包中商品的价值。举个栗子:表中价格为3,大小为2开始表格往上生长;直到遇到商品大小为2,价值为6的商品时经过最大化比较背包中九堡原来的
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值