| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 数据结构与算法 -> 第一篇博客——关于01背包问题的学习整理 -> 正文阅读 |
|
[数据结构与算法]第一篇博客——关于01背包问题的学习整理 |
对于大厂面试而言,01背包主要考察两种背包: 1、01背包 n种物品,每种物品只有一个 2、 完全背包 n种物品,每种物品无限个 3、 多重背包 n种物品,每种物品个数各不相同 LeetCode上面没有纯粹的01背包问题,主要是背包问题的应用 下面给出一个简单的01背包问题的例子
其中,背包最大重量为4,可装满的最大价值为? (1)考虑暴力解法 每个物品两个状态:取or不取 因此我们可以用?回溯算法 来枚举所有情况;时间复杂度O(2^n)【这个就涉及到学习回溯算法咯】 (2)二维dp数组解法 动态规划五部曲: 1、明确dp数组含义 ????????dp[i][j] :0 ~ i?之间的物品任取,放进容量为?j?的背包里的最大价值 2、确定递推公式 ? ? ? ? 思考:dp[i][j] 可由哪些状态推导而来?此题中,有两种状态:放物品i or 不放物品i ? ? ? ? 若不放——dp[i - 1][j] ? ? ? ? 放物品i——dp[i - 1][j - weight[i]] + value[i] ? ? ? ? 我们的目的是求最大价值,因此需要在两种状态中取其大者,即: ? ? ? ? dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - weight[i]] + value[i]) ? ? ? ? 上述即为递推公式 3、dp数组的初始化 ? ? ? ? 首先,为了方便分析问题,我们可以先画出二维的dp数组矩阵
? ? ? ? 我们需要初始化什么呢?这个需要具体情况具体分析 ? ? ? ? 在该例中,对于第一列,在背包容量为0的情况下,无法放入任何物品。因此该列可全部初始化为0;对于第一行,在该状态下只有物品0可以选取,那么满足物品0重量的背包状态,皆需要初始化为物品0的value;而对于小于物品0重量的背包状态,无法放入物品0,因此初始化为0。至此,二维dp数组的初始化完成。 ? ? ? ? 问题:在上述初始化完成后,其他的位置该如何进行初始化? ? ? ? ? 很多人都默认初始化为0。运行可通过,但是我们需要思考我们该如何初始化其他位置?其实本题中,初始化为什么都可以。因为下面的每个状态,都是由我们上述的初始化推导而来的,并不受其他因素影响(比如该位置初始值与其他状态的比较) 4、确定遍历顺序 ? ? ? ? 我们通常都知道,一般都是两个for循环来完成遍历。但是,两个for循环分别都是什么含义呢?第一层遍历物品还是背包容量?这个问题不可马虎,需要仔细考虑。对于此题,for循环的次序可以进行颠倒。只要左上方和正上方有数值,就不影响数组推导。 5、举例推导dp数组
?二维dp数组代码实现
?结果为: ?符合推导的dp数组 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/28 11:49:46- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |