JavaScript背包问题动态规划详解
时间:2026-04-11 12:33:46 132浏览 收藏
本文深入浅出地讲解了动态规划在JavaScript中求解经典01背包问题的核心思想与实战实现:面对容量有限的背包和一组具有重量与价值的物品,如何通过状态转移方程精准决策“取或不取”,以最大化总价值;不仅清晰剖析二维DP数组的逻辑构建与递推过程,还进一步优化为高效的一维数组逆序更新方案,在保证正确性的同时显著降低空间复杂度,为前端开发者掌握算法思维与工程化落地提供了兼具理论深度与代码可读性的实用指南。

背包问题是动态规划中的经典问题,主要分为01背包、完全背包和多重背包等类型。这里重点介绍最基础的01背包问题及其在JavaScript中的实现方式。
什么是01背包问题?
给定一个固定容量的背包和一组物品,每个物品有重量和价值,每种物品只能选择一次(拿或不拿),目标是在不超过背包容量的前提下,使装入背包的物品总价值最大。
动态规划解法思路
使用二维数组 dp[i][w] 表示前 i 个物品在容量为 w 时能获得的最大价值:
- 对于每个物品,有两种选择:放入背包或不放入
- 如果不放入,dp[i][w] = dp[i-1][w]
- 如果放入(前提是物品重量 ≤ w),dp[i][w] = dp[i-1][w-weight[i]] + value[i]
- 取两者最大值即可
JavaScript代码实现
以下是解决01背包问题的完整JavaScript函数:
function knapsack(weights, values, capacity) {
const n = weights.length;
// 创建二维DP数组
const dp = Array(n + 1).fill(null).map(() => Array(capacity + 1).fill(0));
<p>// 填充DP表
for (let i = 1; i <= n; i++) {
for (let w = 0; w <= capacity; w++) {
if (weights[i - 1] <= w) {
dp[i][w] = Math.max(
dp[i - 1][w], // 不放当前物品
dp[i - 1][w - weights[i - 1]] + values[i - 1] // 放当前物品
);
} else {
dp[i][w] = dp[i - 1][w]; // 超重,不能放
}
}
}</p><p>return dp[n][capacity];
}</p><p>// 示例使用
const weights = [2, 3, 4, 5];
const values = [3, 4, 5, 6];
const capacity = 8;
console.log(knapsack(weights, values, capacity)); // 输出:10</p>空间优化:一维数组解法
可以将空间复杂度从 O(n×W) 降到 O(W),使用一维数组从后往前更新:
function knapsackOptimized(weights, values, capacity) {
const dp = Array(capacity + 1).fill(0);
<p>for (let i = 0; i < weights.length; i++) {
for (let w = capacity; w >= weights[i]; w--) {
dp[w] = Math.max(dp[w], dp[w - weights[i]] + values[i]);
}
}</p><p>return dp[capacity];
}</p>基本上就这些。掌握状态定义和转移方程是关键,理解后可扩展到完全背包等问题。
今天带大家了解了的相关知识,希望对你有所帮助;关于文章的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~
相关阅读
更多>
-
502 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
最新阅读
更多>
-
322 收藏
-
302 收藏
-
466 收藏
-
397 收藏
-
485 收藏
-
477 收藏
-
181 收藏
-
125 收藏
-
275 收藏
-
304 收藏
-
254 收藏
-
369 收藏
课程推荐
更多>
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习