我正在参加「掘金·启航计划」
前言
--
动态规划(Dynamic Programming,DP)是运筹学的一个分支,是求解决策过程最优化的过程。
问题描述
01背包问题是一个经典的算法问题,简单来说就是一个包要装许多水果,水果有体积和大小两个属性,怎么把包装满价值最大(最值钱)。 专业描述问题:有N件物品和一个容量为v的背包,第i件物品的体积是ci,价值是wi,求将那些物品怎么装进背包使价值总和最大。 注意:物品只能取一次或者不取,不能多次获取
原理
--
f(i,c) = math.Max( f(i-1,c),(f(i-1,c-w[i]) + v[i])) //取最大值
枚举第i个物品,选还是不选
然后需要考虑在剩余容量为c的情况下,从前i个物品中能得到的最大价值和。
案例
--
背包的最大容量为6,其他物品信息如下:
体积
价值
葡萄
2
3
矿泉水
3
5
西瓜
4
6
根据背包容量从0-6以及物品,初始化表格。
第0行在任何容量体积下,没有任何物品,所以都为0,即前0个物品装进背包的价值都为0 。 对于第0列来说,因为背包容量为0,所以任何物品都不能装进背包,所以价值都为0,即第0列数据都为0。虽然是第0行第0列,但是都是在各自限制条件下的最优解。
<script>
let weight = [2, 3, 4];//物体体积
let value = [3, 5, 6];//物体价值
let bagWeight = 6;//背包最大容纳量
function bagProblem(weight, value, bagWeight) {
// 初始化dp,生成二维数组,长度为物体种类总长度,里面的数组长度为(背包最大容纳量+1)
const dp = new Array(weight.length + 1).fill(0).map(() => new Array(bagWeight + 1).fill(0));
//此时dp为
//[[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0]]
// 设置第一个物品在背包体积为(0-6)中的最优解
for (let j = weight[0]; j <= bagWeight; j++) { //i<= 4
dp[0][j] = value[0]
}
//此时dp为
//[[0, 0, 3, 3, 3,3,3],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0],
//[0, 0, 0, 0, 0,0, 0]]
for (let j = 0; j <= bagWeight; j++) { //0<=4 j为包的最大重量
for (let i = 1; i < weight.length; i++) { // 1<=3 i为三个包的索引
if (j < weight[i]) { // 包的最大重量 < 第i个包的重量,此时最优解为继承上一个单元格
dp[i][j] = dp[i - 1][j] //dp[i][j]
} else {
// 包的最大重量 < 第i个包的重量
//Math.max(前一条数据最优解,(此时容纳量-当前选择物体的容纳量)的最优解 + 此时物体的价值)
dp[i][j] = Math.max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i])
}
}
}
return dp[weight.length - 1][bagWeight]
}
bagProblem(weight, value, bagWeight)
console.log(bagProblem(weight, value, bagWeight))
</script>
我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
扫码关注腾讯云开发者
领取腾讯云代金券
Copyright © 2013 - 2025 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有
深圳市腾讯计算机系统有限公司 ICP备案/许可证号:粤B2-20090059 深公网安备号 44030502008569
腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287
Copyright © 2013 - 2025 Tencent Cloud.
All Rights Reserved. 腾讯云 版权所有