0

0

C++怎么解决背包问题_C++经典DP教程【优化】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-02-26 09:05:03

|

813人浏览过

|

来源于php中文网

原创

倒序遍历是为了避免重复选取同一物品,确保0-1背包的“每物至多一次”约束;正向遍历会误成完全背包。

c++怎么解决背包问题_c++经典dp教程【优化】

0-1 背包用 std::vector 一维数组滚动更新时,为什么循环要倒着写?

因为正向遍历会重复使用当前轮次已更新的状态,把 0-1 背包变成完全背包——你本想每个物品只选一次,结果它被反复塞进去了。

倒序遍历 dp[j](从 Wweight[i])能确保每次更新只依赖上一轮(即未被本轮修改过的)状态。

  • 正向:更新 dp[5] 后,dp[10] 可能又用到这个新 dp[5],相当于多拿了一次第 i 个物品
  • 倒序:所有 j 对应的 dp[j - weight[i]] 都还是上一轮值,严格保证“每物至多一次”
  • 边界注意:内层循环下界是 weight[i],不是 0;小于它的容量根本装不下当前物品

std::vector<int></int> 初始化大小和初值搞错会导致什么?

背包问题里最常写成 std::vector<int> dp(W + 1, 0)</int>,但如果你写成 dp(W, 0) 或漏掉 +1,就会访问越界或漏掉容量为 W 的情况。

错误示例:dp[W] 是合法下标,所以数组长度必须是 W + 1。否则 dp[W] 访问的是未分配内存,运行时可能崩溃或返回随机值。

立即学习C++免费学习笔记(深入)”;

SONIFY.io
SONIFY.io

设计和开发音频优先的产品和数据驱动的解决方案

下载
  • 初始化为 -1 表示“不可达”时,记得全填满:std::vector<int> dp(W + 1, -1)</int>
  • 若用 INT_MIN 做无效标记,别忘了 #include <climits></climits>,且加法前检查是否仍为 INT_MIN,避免溢出
  • 不要用 dp.resize(W + 1) 后再手动赋值——容易漏初始化,直接构造更稳

物品体积为 0 怎么办?

标准 0-1 背包假设所有 weight[i] > 0。一旦出现 weight[i] == 0,倒序循环就失效:j - 0 == j,你总在用刚算出来的 dp[j] 更新自己,导致无限叠加。

实际中这类物品要么全拿(如果价值 > 0),要么全不拿(如果价值 ≤ 0)。得单独预处理。

  • 先扫一遍,统计所有 weight[i] == 0 && value[i] > 0 的价值和,加到最终答案里
  • 把这类物品从输入中剔除,再跑常规 DP
  • 别想着在 DP 循环里特判 weight[i] == 0——逻辑混杂,易错且难调试

空间优化后还能还原具体选了哪些物品吗?

不能直接还原。一维 dp 数组只存最大价值,丢掉了决策路径信息。

如果题目要求输出方案(比如打印选了哪几个物品),必须保留二维状态,或者额外维护一个 choice 数组记录每步决策。

  • 简单做法:用 std::vector<:vector>> choice(n + 1, std::vector<bool>(W + 1))</bool></:vector>,在更新 dp[i][j] 时同步记下是否选了第 i
  • 省空间做法:只存最后一行 choice[j],回溯时从 dp[W] 往前推,但需保存每轮的 weightvalue,且无法支持多解任意输出
  • 真正卡内存时,宁愿用文件或调试输出临时查中间态,也别为了省几十字节让方案还原逻辑变得脆弱

DP 状态压缩很优雅,但“知道最优值”和“知道怎么达到最优”是两件事。后者永远比前者重得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

850

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

585

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

210

2025.08.29

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

127

2026.02.25

Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法
Steam官网正版入口与注册登录指南_新手快速进入游戏平台方法

本专题系统整理Steam官网最新可用入口,涵盖网页版登录地址、新用户注册流程、账号登录方法及官方游戏商店访问说明,帮助新手玩家快速进入Steam平台,完成注册登录并管理个人游戏库。

18

2026.02.25

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

15

2026.02.25

Python数据处理流水线与ETL工程实战
Python数据处理流水线与ETL工程实战

本专题聚焦 Python 在数据工程场景下的实际应用,系统讲解 ETL 流程设计、数据抽取与清洗、批处理与增量处理方案,以及数据质量校验与异常处理机制。通过构建完整的数据处理流水线案例,帮助开发者掌握数据工程中的性能优化思路与工程化规范,为后续数据分析与机器学习提供稳定可靠的数据基础。

1

2026.02.25

Java领域驱动设计(DDD)与复杂业务建模实战
Java领域驱动设计(DDD)与复杂业务建模实战

本专题围绕 Java 在复杂业务系统中的建模与架构设计展开,深入讲解领域驱动设计(DDD)的核心思想与落地实践。内容涵盖领域划分、聚合根设计、限界上下文、领域事件、贫血模型与充血模型对比,并结合实际业务案例,讲解如何在 Spring 体系中实现可演进的领域模型架构,帮助开发者应对复杂业务带来的系统演化挑战。

1

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.2万人学习

C 教程
C 教程

共75课时 | 5万人学习

C++教程
C++教程

共115课时 | 19.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号