javaScript实现动态规划(Dynamic Programming)01背包问题
创始人
2025-05-28 04:14:32
0

🐱 个人主页:不叫猫先生
🙋‍♂️ 作者简介:前端领域新星创作者、阿里云专家博主,专注于前端各领域技术,共同学习共同进步,一起加油呀!
💫系列专栏:vue3从入门到精通、TypeScript从入门到实践
📢 资料领取:前端进阶资料以及文中源码可以找我免费领取
🔥 前端学习交流:博主建立了一个前端交流群,汇集了各路大神,一起交流学习,期待你的加入!(文末有我wx或者私信)

目录

    • 前言
    • 问题描述
    • 原理
    • 案例

前言

动态规划(Dynamic Programming,DP)是运筹学的一个分支,是求解决策过程最优化的过程。

问题描述

01背包问题是一个经典的算法问题,简单来说就是一个包要装许多水果,水果有体积和大小两个属性,怎么把包装满价值最大(最值钱)。
专业描述问题:有N件物品和一个容量为v的背包,第i件物品的体积是c[i],价值是w[i],求将那些物品怎么装进背包使价值总和最大。
注意:物品只能取一次或者不取,不能多次获取

在这里插入图片描述

原理

f(i,c) = math.Max( f(i-1,c),(f(i-1,c-w[i]) + v[i])) //取最大值

枚举第i个物品,选还是不选

  • 选:容量减少了w[i]
  • 不选:剩余容量不变

然后需要考虑在剩余容量为c的情况下,从前i个物品中能得到的最大价值和。

  • 不选:在剩余容量为c时,从前i-1个物品中获得最大价值和
  • 选:在剩余容量为c-w[i]的时候,从前i-1个物品中获取最大价值和
    最终取两者的最大值

案例

背包的最大容量为6,其他物品信息如下:

体积价值
葡萄23
矿泉水35
西瓜46

根据背包容量从0-6以及物品,初始化表格。

在这里插入图片描述
表格中的单元格代表的是什么意思呢?以图中为例:第2行第4列的单元格表示背包容量最大为3的情况下,对前2类物品进行选择,使得背包的价值为最大值。
第i行第j列的单元格 表示背包容量最大为j的情况下,对前i类物品进行选择,能使得背包的价值为最大值。每个单元格都是当前条件下的最优解,表格的右下角的单元格就是最优解

在这里插入图片描述

第0行在任何容量体积下,没有任何物品,所以都为0,即前0个物品装进背包的价值都为0 。
对于第0列来说,因为背包容量为0,所以任何物品都不能装进背包,所以价值都为0,即第0列数据都为0。虽然是第0行第0列,但是都是在各自限制条件下的最优解。

  • 分析第一行第一列的单元格
    在背包容量最大为1的条件下,对前一种物品取舍选择后获得的最大价值。在考虑单元格的时候需要进行判断:新纳入考量的物品是否超过背包的总容量。第一行第一列这里新纳入的物品为葡萄,葡萄的体积(2)大于背包体积(1),所以放不进去。
    我们已经计算出不考虑葡萄时候,最大价值为0 ,此时我们的最优解继承自其上方单元格也就是(0,1)的值

  • 分析第一行第二列的单元格
    在背包容量最大为2的条件下,对前一种物品取舍选择后获得的最大价值。此时物体体积等于背包体积,此时不能继承上方单元格的值,也就是不能继承(0,2)的数据。此时需要比较两种数据的大小:

    • 不考虑新纳入物品(也就是说不考虑此时葡萄获得的最优解),这个最优解为上方单元格的最优解(第0个物品在背包体积为2的情况的最优解:0)
    • 背包容量为2的情况下,对前一种物品取舍选择后获得的最大价值,此时刚好可以放进背包,那么问题就变成了背包容量为0的情况下对前一种物品取舍选择后获得的最大价值 + 当前物品的价值(此时为葡萄🍇)。变成了背包容量为0的情况是通过当前背包容量(2) - 此时物品容量(2) = 0。
    • 然后比较两者大小,取最大值
  • 分析其他单元格与上面类似,最终得到右下方单元格的值(最优解)
    最终计算完得到以下结果
    在这里插入图片描述

	

相关内容

热门资讯

安卓系统开后门怎么开,操作步骤... 你有没有想过,你的安卓手机里可能藏着一个秘密通道,一个可以让你轻松掌控手机的小技巧?没错,我要说的就...
京东和安卓系统哪个好用,谁更胜... 最近是不是也被京东和安卓系统哪个更好用的问题给困扰住了?咱们来好好聊聊这个话题,看看哪个更适合你!京...
安卓跟鸿蒙系统的区别,系统架构... 你有没有发现,现在手机市场上的操作系统真是五花八门,让人挑花了眼?其中,安卓和鸿蒙系统可谓是两大巨头...
让安卓拥有ios系统,揭秘iO... 你知道吗?在科技圈里,最近有个热门话题可是让不少安卓用户心动不已——那就是让安卓拥有iOS系统!想象...
怎样看系统版本安卓,从历史演变... 你有没有发现,手机里的系统版本安卓,就像是它的身份证号码,独一无二,也透露着它的“年龄”和“身份”。...
安卓平板电脑改双系统,轻松实现... 你有没有想过,你的安卓平板电脑可以变身成双系统战士呢?没错,就是那种既能流畅运行安卓应用,又能轻松驾...
屏蔽安卓键盘进不了系统 你是不是也遇到了这个问题?手机屏幕上那个小小的键盘突然变得神秘起来,不管你怎么按,就是进不了系统。别...
跑滴滴用安卓系统好吗,安卓系统... 你有没有想过,跑滴滴的时候用安卓系统到底怎么样呢?这可是个挺实际的问题,毕竟现在手机市场这么丰富,选...
电脑双系统安卓win,安卓与W... 你有没有想过,你的电脑里可以同时装着两个世界?一个世界是熟悉的Windows,另一个世界是充满活力的...
安卓系统手机照片找回,轻松恢复... 手机里的照片丢失了,是不是瞬间感觉心都揪紧了?别慌,今天就来和你聊聊安卓系统手机照片找回的那些事儿,...
安卓系统平板修复方法,安卓平板... 你的安卓系统平板突然罢工了,是不是心里有点慌?别担心,今天就来给你支几招,让你的平板重焕生机! 一、...
forget安卓和ios系统好... 你有没有想过,那些陪伴你走过安卓和iOS系统更迭的好友,如今却因为系统差异而渐行渐远?别急,今天就来...
鸿蒙怎么体验原生安卓系统,体验... 你有没有想过,你的鸿蒙手机也能体验到原生安卓系统的魅力呢?没错,就是那个流畅、自由、充满个性的安卓系...
安卓安装windows双系统,... 你有没有想过,在你的安卓手机上安装一个Windows系统呢?听起来是不是有点不可思议?但别急,今天我...
安卓系统电脑怎么连无线,安卓电... 你有没有想过,家里的安卓系统电脑怎么连上无线网呢?这可是现代生活中的一大必备技能哦!别急,今天就来手...
a20安卓纯净系统,打造极致流... 你有没有想过,手机系统就像是我们生活的环境,有时候太杂乱无章,让人头疼不已。今天,就让我带你走进一个...
原生安卓怎么清理系统,提升性能 你的安卓手机是不是也像你的钱包一样,越用越鼓,里面的“垃圾”越来越多?别急,今天就来教你怎么清理原生...
安卓系统全球装机量多少,引领智... 你有没有想过,那个陪伴我们日常生活的安卓系统,它的全球装机量究竟有多么庞大呢?想象从手机到平板,再到...
安卓系统和emui系统怎么样,... 你有没有发现,现在手机市场上安卓系统和华为的EMUI系统简直就是一对“好基友”啊!它们不仅在国内市场...
安卓44系统怎么升级ios,安... 你有没有想过,把你的安卓手机升级成苹果的iOS系统呢?想象那流畅的操作体验,那独特的应用生态,是不是...