当前位置: 首页 > ops >正文

【算法】:动态规划--背包问题

背包问题

引言

什么是背包问题?
背包问题就是一个有限的背包,给出一定的物品,如何合理的装入物品使得背包中的物品的价值最大?

01背包

01背包,顾名思义就是每一种给定的物品要么选择,要么不选,求出最终最大的价值。
针对01背包又有两种情况,一种情况是要求最终装满背包,第二种是不用一定装满背包。
下面给出一道例题,并且给出01背包的dp解法。

  1. leetcode LCR 101 : 分割等和子集
    在这里插入图片描述
    解题思路:
    明显,我们可以理解为这里有一个Sum{ai} / 2的背包,我们需要将他装满,这道题比较简单,没有value值。
    状态转移方程:(01背包常见的状态转移方程)
  • dp[i][j] : 前i个元素能够填充大小为j的背包的最大价值
  • dp[i][j] = max { dp[i - 1][j] , dp[i -1][j - Size[i]] + value[i] }

第i个位置,可以不选择它装入背包, 这个时候为dp[i - 1][j] , 也可以选择,这个时候为dp[i -1][j - Size[i]] + value[i]

细节: 
1. 判断j >= Size[i] 
2. 初始化size的时候 + 1,可以更好处理边界条件

在这里插入图片描述
总结:其实无论是否一定需要装满,状态转换方程都差不多,最大的差别是初始化dp的时候存在较大的差异,希望读者注意。

完全背包

完全背包,和01背包的差异就是每一种物品可以选取多次,其他一样,也是可以分为装满和不需要一定装满两种情况。
不太会Latex, 只有手绘。
请添加图片描述
例题:leetcode LRC 103 零钱兑换
在这里插入图片描述
解法:
在这里插入图片描述

总结

这里列举了常见的基础背包问题的解法,再往后学习就是竞赛难度的背包问题,这里我们不再继续赘述,读者想要了解更加复杂的背包问题,可以自行继续探索。

http://www.xdnf.cn/news/8630.html

相关文章:

  • Linux常用下载资源命令
  • OpenLayers 加载导航与基本操作控件
  • AD9268、AD9643调试过程中遇到的问题
  • Linux的读写屏障
  • Mysql 通过案例快速学习常见操作
  • 索引下探(Index Condition Pushdown,简称ICP)
  • 大模型介绍
  • 动态规划dp
  • Java中==和equals()的终极对比
  • SpikingYOLOX
  • GATT 服务的核心函数bt_gatt_discover的介绍
  • Day 34
  • Docker 镜像标签(Tag)规范与要求
  • 历史数据分析——宁波港
  • 防火墙流量管理-带宽管理
  • OpenLayers 加载图层探查控件
  • Linux系统移植①:uboot概念
  • 基于规则匹配实现企业政策精准匹配实战案例
  • 《Java vs Go:现代编程语言的核心差异与设计哲学对比》
  • nginx 基于IP和用户的访问
  • LangGraph的智能评估
  • 【深度学习新浪潮】什么是MCP?
  • LangGraph:部署智能应用
  • 地理特征类相关可视化图像总结
  • stream数据流
  • 电子电路:再谈滤波原理及其应用
  • 再谈Linux 进程:进程等待、进程替换与环境变量
  • [Solution] git push error (exit code 128)
  • linux 内存碎片分析
  • Firecrawl MCP Server 深度使用指南