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。
    • 然后比较两者大小,取最大值
  • 分析其他单元格与上面类似,最终得到右下方单元格的值(最优解)
    最终计算完得到以下结果
    在这里插入图片描述

	

相关内容

热门资讯

[LeetCode周赛复盘] ... [LeetCode周赛复盘] 第 337 场周赛20230319 一、本周周赛总结二、 [Easy]...
20.有效的括号 给定一个只包括 '(',')','{','}'࿰...
FPGA基于RIFFA实现PC... 目录1、前言2、RIFFA理论基础3、设计思路和架构4、vivado工程详解5、上板调试验证并演示6...
Vue学习计划二:了解Vue组... Vue组件是Vue.js应用程序的构建块,它允许开发者将应用程序拆分成小的、可重用的部...
血氧仪是如何得出血氧饱和度值的... 目录 一、血氧饱和度概念 二、血氧饱和度监测意义  三、血氧饱和度的监测方式 四、容积脉搏波计算血氧...
GNURadio RTL-SD... 关于LTE-Cell-Scanner 由Xianjun Jiao在github开源,主...
Excel 如何在替换0时,不... 有时我们需要把值是0的数据进行替换,而不替换含0的值如10,100,20等࿰...
栈(数据结构系列7) 前言: 这节中小编带你了解数据结构中的栈结构和队列结构,以及分别自己模拟...
随想录二刷Day22——二叉树 文章目录二叉树26. 二叉树的最近公共祖先28. 二叉搜索树的最近公共祖先29. 二叉搜索树中的插入...
[图神经网络]图特征工程 一、图的特征         图点本身就具备的特征称为属性特征(如:连接...
springboot车辆充电桩 sprinboot车辆充电桩演示录像2022 开发语言:Java 框架:...
c 语言学习的技巧是什么? C语言是一种通用的、过程式的编程语言,由贝尔实验室的Dennis Ritchie在20...
【Java项目】完善基于Jav... 目录一、准备工作二、引入依赖三、创建必要的目录四、编写代码五/六、打包部署(直接基于 smart t...
GeoWave 以下部分内容是翻译的。英文太烂,应该是很不准确的。 一、什么是GeoWave GeoW...
smtp报文分析(25、465... 对于用到的工具和对应的环境配置可以参见 smtp 抓包_Steven-Russell的博客-CSDN...
Qt demo——修改用户资料... 一、效果展示 基本信息界面 联系方式界面 详细资料界面 二、实现 1.窗口布局 左边是一个 ...
“华为杯”研究生数学建模竞赛2...  赛题描述 文中涉及数据详见华为杯2007年D题附件 邮局间直达公路里程-数据集 一、问题的来源及意...
pytorch单张图片预测,如... 1. 批量读取 trainset, valset, testset = get_dataset(cf...
百度文心一言正式亮相 OpenAI 刚发布了 GPT-4,百度预热已久的人工智能生成式对话产品也终于亮相了。...
学习go语言的一些笔记(二) 1 指针 指针是一种数据类型,相当于用一个变量 去存储一个数据地址,这个...