0

0

C++怎么实现动态规划_C++DP入门教程【状态】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-03-14 19:38:30

|

456人浏览过

|

来源于php中文网

原创

DP状态定义必须精确,如LIS中dp[i]应明确为“以nums[i]结尾的严格递增子序列最大长度”;转移前须确保j合法且nums[j]<nums[i],背包中需检查w≥weight[i]再访问dp[w-weight[i]]。

c++怎么实现动态规划_c++dp入门教程【状态】

DP状态定义不明确,程序就跑不起来

动态规划在C++里不是靠套模板,而是靠想清楚「状态是什么」。比如求最长上升子序列,dp[i] 不能模糊地写成“以第i个数结尾的答案”,得明确是「以nums[i]结尾的严格递增子序列的最大长度」——少一个限定词,转移时就可能越界或漏情况。

常见错误现象:dp[i] = max(dp[j] + 1) 中没加 nums[j] 判断,结果全算成最长子数组;或者把状态设成「前i个数中的LIS长度」,导致无法转移(因为不知道末尾值,没法接新数)。

  • 状态必须可转移:能从已有状态推出新状态,且只依赖更小的索引或已计算子问题
  • 状态维度要够用:一维不够就加维,比如背包问题加容量维度 → dp[i][w]
  • 初始化别硬填0:dp[0] = 1 是常识,但像区间DP常要初始化所有 dp[i][i] = 10,取决于问题语义

vector初始化大小和默认值容易出错

C++里vector不初始化就访问会UB,而DP几乎全靠它存状态。比如想开二维dp[n][m],写成 vector<vector>> dp(n, vector<int>(m))</int></vector> 没问题,但若漏掉第二层大小:vector<vector>> dp(n)</vector>,后续dp[i].push_back(...) 就变成模拟而非随机访问,时间复杂度直接升到O(n²)甚至更高。

使用场景:刷题常用vector,但工程中若确定尺寸且性能敏感,array或裸数组更快;不过DP题基本都用vector,因为n常由输入决定。

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

  • 初始化带默认值更安全:vector<int> dp(n, -1)</int>vector<int>(n)</int> 更易调试(-1比0更容易暴露未更新状态)
  • 滚动数组优化时,别只改dp变量名不改尺寸:比如从dp[i][j]压到dp[j],仍需保证dp大小 ≥ m,否则越界
  • 注意vector构造函数参数顺序:vector<int>(size, value)</int>,反了会创建一堆0再赋值,白耗内存

状态转移时忘记边界检查和条件过滤

for (int j = 0; j 然后直接<code>if (dp[j] > 0) dp[i] = max(dp[i], dp[j] + 1),看着没问题,但实际可能因j对应的状态根本不可达(比如背包里重量超限),导致用无效值更新答案。

典型错误:在01背包中,内层循环从w = weight[i]开始是对的,但有人写成for (int w = 0; w ,然后<code>if (w >= weight[i]),逻辑对但效率低;更糟的是漏掉if,直接访问dp[w - weight[i]],造成负索引越界。

  • 所有下标访问前必须检查是否在合法范围内:j >= 0 && j ,尤其滚动数组里<code>w - weight[i]可能为负
  • 条件判断要和状态定义严格对齐:比如「恰好装满」背包要求初始化dp[0] = 0、其余为-INF,否则dp[W]可能来自未装满的中间状态
  • 浮点DP慎用==比较:用abs(a - b) ,否则<code>dp[i] == dp[j]可能永远为假

记忆化搜索 vs 递推:选错实现方式会卡死或超内存

纯递归+memo适合状态稀疏或转移方向不规则的问题(比如某些博弈DP、树形DP),而填表式递推更适合状态密集、有明确方向的问题(如LIS、背包)。用记忆化硬写背包,最坏可能递归深度达W,爆栈;用递推硬写某些图上DP,可能遍历大量无效状态,TLE。

性能影响明显:记忆化平均只算真正需要的状态,但每次函数调用有开销;递推无调用开销,但可能填满整个dp表,空间多一倍(比如二维压成一维后还多开一行)。

  • 先画状态依赖图:如果依赖关系是DAG且边稀疏,优先记忆化;如果能按索引单调推进(i→i+1,w→w+1),递推更稳
  • memo数组别用map存二维键:map<pair>, int></pair>vector<vector>></vector> 慢10倍以上,除非状态确实非常稀疏
  • 递推注意循环顺序:01背包倒序,完全背包正序,写反了就变成无限物品——这不是bug,是逻辑错,调试时很难一眼看出

状态设计不对,后面全是白忙;边界不守,程序当场崩;选错实现方式,可能本地快但评测机上栈溢出或MLE。这些地方没有银弹,只能一个个case抠。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

847

2023.08.22

string转int
string转int

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

1051

2023.08.02

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

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

615

2024.08.29

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

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

335

2025.08.29

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

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

235

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

447

2023.07.18

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

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

精品课程

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

共94课时 | 11.3万人学习

C 教程
C 教程

共75课时 | 5.4万人学习

C++教程
C++教程

共115课时 | 21.9万人学习

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

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