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

背包DP:从入门到精通的动态规划指南

背包DP的基本概念背包动态规划Knapsack DP是一类经典的优化问题通常描述为给定一组物品每个物品有重量和价值在不超过背包承重限制的前提下选择物品使得总价值最大。背包问题分为多种类型如0-1背包、完全背包、多重背包等。0-1背包问题0-1背包是最基础的背包问题每个物品只能选择一次选或不选。其状态转移方程为 [ dp[i][j] \max(dp[i-1][j], dp[i-1][j-w[i]] v[i]) ] 其中( dp[i][j] ) 表示前 ( i ) 个物品在背包容量为 ( j ) 时的最大价值( w[i] ) 和 ( v[i] ) 分别为第 ( i ) 个物品的重量和价值。实现代码int knapsack_01(vectorint weights, vectorint values, int capacity) { int n weights.size(); vectorvectorint dp(n 1, vectorint(capacity 1, 0)); for (int i 1; i n; i) { for (int j 0; j capacity; j) { if (j weights[i-1]) { dp[i][j] max(dp[i-1][j], dp[i-1][j-weights[i-1]] values[i-1]); } else { dp[i][j] dp[i-1][j]; } } } return dp[n][capacity]; }空间优化由于状态转移只依赖前一行可以将二维数组优化为一维数组int knapsack_01_optimized(vectorint weights, vectorint values, int capacity) { vectorint dp(capacity 1, 0); for (int i 0; i weights.size(); i) { for (int j capacity; j weights[i]; --j) { dp[j] max(dp[j], dp[j - weights[i]] values[i]); } } return dp[capacity]; }完全背包问题完全背包允许每个物品选择多次。状态转移方程为 [ dp[i][j] \max(dp[i-1][j], dp[i][j-w[i]] v[i]) ] 注意与0-1背包的区别完全背包的状态转移是从同一行更新。实现代码int knapsack_unbounded(vectorint weights, vectorint values, int capacity) { vectorint dp(capacity 1, 0); for (int i 0; i weights.size(); i) { for (int j weights[i]; j capacity; j) { dp[j] max(dp[j], dp[j - weights[i]] values[i]); } } return dp[capacity]; }多重背包问题多重背包限制每个物品最多选择 ( k[i] ) 次。可以通过二进制拆分或单调队列优化实现。二进制拆分实现将每个物品拆分为多个“虚拟物品”转化为0-1背包问题int knapsack_bounded(vectorint weights, vectorint values, vectorint counts, int capacity) { vectorint dp(capacity 1, 0); for (int i 0; i weights.size(); i) { int k 1; while (k counts[i]) { int w k * weights[i]; int v k * values[i]; for (int j capacity; j w; --j) { dp[j] max(dp[j], dp[j - w] v); } counts[i] - k; k * 2; } if (counts[i] 0) { int w counts[i] * weights[i]; int v counts[i] * values[i]; for (int j capacity; j w; --j) { dp[j] max(dp[j], dp[j - w] v); } } } return dp[capacity]; }背包问题的变种恰好装满背包初始化时 ( dp[0] 0 )其余为 ( -\infty )确保只有恰好装满的状态才有效。方案计数修改状态转移方程累加方案数而非取最大值 [ dp[j] dp[j - w[i]] ]多维费用背包增加状态维度例如限制体积和重量 [ dp[i][j][k] \max(dp[i-1][j][k], dp[i-1][j-v1[i]][k-v2[i]] w[i]) ]常见例题分析分割等和子集LeetCode 416问题转化为0-1背包判断是否能选出部分元素和为总和的一半bool canPartition(vectorint nums) { int sum accumulate(nums.begin(), nums.end(), 0); if (sum % 2 ! 0) return false; int target sum / 2; vectorbool dp(target 1, false); dp[0] true; for (int num : nums) { for (int j target; j num; --j) { dp[j] dp[j] || dp[j - num]; } } return dp[target]; }零钱兑换LeetCode 322完全背包问题求最小硬币数int coinChange(vectorint coins, int amount) { vectorint dp(amount 1, amount 1); dp[0] 0; for (int coin : coins) { for (int j coin; j amount; j) { dp[j] min(dp[j], dp[j - coin] 1); } } return dp[amount] amount ? -1 : dp[amount]; }背包DP的优化技巧滚动数组通过交替使用两行数组减少空间复杂度。单调队列优化适用于多重背包将时间复杂度从 ( O(N \cdot V \cdot K) ) 降为 ( O(N \cdot V) )。常数优化在内层循环中提前终止或调整遍历顺序。常见错误与调试初始化错误未正确处理边界条件如容量为0时的初始化。遍历顺序错误0-1背包必须逆序遍历容量完全背包需正序遍历。状态转移混淆注意区分“选”与“不选”时的状态来源当前行或上一行。背包DP的扩展应用树形背包在树结构上进行DP通常结合后序遍历实现。分组背包每组物品只能选一个增加一维状态表示组别。依赖背包物品之间存在依赖关系需转化为树形结构处理。总结背包DP的核心在于状态定义和转移方程的设计。通过分析问题类型0-1、完全、多重和约束条件容量、费用维度选择合适的实现方式。优化空间复杂度和时间复杂度是提高效率的关键而变种问题则需要灵活调整状态转移逻辑。

相关文章:

背包DP:从入门到精通的动态规划指南

背包DP的基本概念背包动态规划(Knapsack DP)是一类经典的优化问题,通常描述为:给定一组物品,每个物品有重量和价值,在不超过背包承重限制的前提下,选择物品使得总价值最大。背包问题分为多种类型…...

PTA L1-064 AI核心代码:从“估值一亿”到“精准通关”的算法拆解与避坑指南

1. 从"估值一亿"到精准通关:AI核心代码的工程思维 第一次看到PTA L1-064这个题目时,我差点笑出声——"估值一亿的AI核心代码"这个描述也太夸张了吧?但仔细研究题目要求后,我发现这道题确实暗藏玄机。表面看只…...

Windows多显示器DPI缩放终极指南:如何用SetDPI精准解决显示不一致问题

Windows多显示器DPI缩放终极指南:如何用SetDPI精准解决显示不一致问题 【免费下载链接】SetDPI 项目地址: https://gitcode.com/gh_mirrors/se/SetDPI 你是否经常遇到这样的困扰?当你的笔记本电脑连接到4K外接显示器时,代码编辑器在笔…...

别再复制粘贴了!手把手教你用TypeScript封装一个企业级axios请求库(附完整源码)

从零构建高可维护的TypeScript请求库:axios企业级封装实战 每次在Vue3项目中新建一个页面,你是否习惯性打开旧项目复制粘贴网络请求代码?当接口字段变更时,是否需要在十几个文件中逐个修改错误处理逻辑?这种重复劳动不…...

如何用开源智能工具一键提升你的英雄联盟游戏体验

如何用开源智能工具一键提升你的英雄联盟游戏体验 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power 🚀. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 想要在英雄联盟中更高效地获取信息、减少重复…...

Rust crate 构建与依赖管理

Rust作为一门现代系统编程语言,凭借其出色的性能与安全性吸引了大量开发者。而Rust的模块化设计核心——crate(代码库)的构建与依赖管理,则是每个Rust开发者必须掌握的关键技能。无论是构建小型工具还是大型项目,高效的…...

clickhouse可以表关联吗

ClickHouse 完全支持表关联(JOIN),但语法和性能特性与传统数据库有所不同。ClickHouse JOIN 类型表格JOIN 类型语法说明INNER JOINSELECT ... FROM a INNER JOIN b ON a.id b.id标准内连接LEFT JOINSELECT ... FROM a LEFT JOIN b ON a.id …...

Halcon实战:用area_center算子快速搞定图像区域面积与中心点计算(附完整代码)

Halcon实战:用area_center算子快速搞定图像区域面积与中心点计算(附完整代码) 在工业质检、医疗影像或自动化测量领域,图像区域的面积与中心点坐标是最基础却至关重要的特征参数。想象一下这样的场景:生产线上需要统计…...

Windows平台微信/QQ/TIM防撤回补丁完整使用指南:如何实现消息保护与多开功能

Windows平台微信/QQ/TIM防撤回补丁完整使用指南:如何实现消息保护与多开功能 【免费下载链接】RevokeMsgPatcher :trollface: A hex editor for WeChat/QQ/TIM - PC版微信/QQ/TIM防撤回补丁(我已经看到了,撤回也没用了) 项目地址…...

HDLbits实战解析:从状态机基础到One-Hot编码进阶

1. 状态机基础与HDLbits实战入门 第一次接触状态机时,我也被那些抽象的状态转换图绕得头晕。直到在HDLbits上刷完Fsm3这道题,才真正理解状态机就像自动售货机的工作逻辑 - 投币、选择、出货,每个动作都对应明确的状态跳转。HDLbits平台最棒的…...

嵌入式开发工具

嵌入式开发工具:赋能智能硬件的核心技术引擎 在万物互联的时代,嵌入式系统已成为智能设备的核心大脑,而开发工具则是构建这一大脑的"手术刀"。从智能家居到工业自动化,嵌入式开发工具通过高效的代码编写、调试和优化&a…...

第9章 函数-9.4 函数参数的传递

在Python中,根据实参的数据类型,可以将函数参数的传递模式分为2种,一是值传递,其包括整数、浮点数、字符串和元组;二是引用传递,其包括列表、字典、集合和对象。值传递和引用传递的区别是,函数参…...

3分钟快速上手Aider:终极AI结对编程助手完全指南

3分钟快速上手Aider:终极AI结对编程助手完全指南 【免费下载链接】aider aider is AI pair programming in your terminal 项目地址: https://gitcode.com/GitHub_Trending/ai/aider 你是否渴望在终端中拥有一个能理解你代码库的AI编程伙伴?Aider…...

BilibiliDown视频下载器终极完整指南:5分钟从新手到高手

BilibiliDown视频下载器终极完整指南:5分钟从新手到高手 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mirrors…...

万字干货 | OpenClaw 进阶玩法大全:技能 / 多 Agent / 省钱 / 安全,+ 实战技巧一次学会图

1.概述在人工智能快速发展的今天,AI不再仅仅是回答问题的聊天机器人,而是正在演变为能够主动完成复杂任务的智能代理。OpenAI的Codex CLI就是这一趋势的典型代表——一个跨平台的本地软件代理,能够在用户的机器上安全高效地生成高质量的软件变…...

Docker Swarm 搞定高可用集群,生产环境再也不怕服务挂掉了

Docker Swarm是什么? Docker Swarm 是 Docker 官方推出的容器集群管理工具,基于 Go 语言实现。代码开源在:https://github.com/docker/swarm 使用它可以将多个 Docker 主机封装为单个大型的虚拟 Docker 主机,快速打造一套容器云平…...

如何5分钟搞定抖音批量下载:douyin-downloader完整使用指南

如何5分钟搞定抖音批量下载:douyin-downloader完整使用指南 【免费下载链接】douyin-downloader A practical Douyin downloader for both single-item and profile batch downloads, with progress display, retries, SQLite deduplication, and browser fallback …...

如何实现零训练深度换脸:roop-unleashed终极指南

如何实现零训练深度换脸:roop-unleashed终极指南 【免费下载链接】roop-unleashed Evolved Fork of roop with Web Server and lots of additions 项目地址: https://gitcode.com/gh_mirrors/ro/roop-unleashed 在当今数字内容创作爆炸的时代,视频…...

OneMore插件终极指南:3步解锁OneNote隐藏的160+效率神器

OneMore插件终极指南:3步解锁OneNote隐藏的160效率神器 【免费下载链接】OneMore A OneNote add-in with simple, yet powerful and useful features 项目地址: https://gitcode.com/gh_mirrors/on/OneMore 还在为OneNote功能单一而烦恼?OneMore插…...

04 前端 Web 开发 HTML5 + CSS3 + 移动 web 视频教程,前端web入门首选黑马程序员

04 前端 Web 开发 HTML5 CSS3 移动 web 视频教程,前端web入门首选黑马程序员 一、参考资料 【前端Web开发HTML5CSS3移动web视频教程,前端web入门首选黑马程序员】 https://www.bilibili.com/video/BV1kM4y127Li/?p44&share_sourcecopy_web&vd…...

Markdown Viewer:浏览器中的终极Markdown渲染神器,让你告别单调预览

Markdown Viewer:浏览器中的终极Markdown渲染神器,让你告别单调预览 【免费下载链接】markdown-viewer Markdown Viewer / Browser Extension 项目地址: https://gitcode.com/gh_mirrors/ma/markdown-viewer 还在为Markdown文件的预览效果发愁吗&…...

如何用5分钟彻底解决BT下载速度慢的问题?终极Tracker列表指南

如何用5分钟彻底解决BT下载速度慢的问题?终极Tracker列表指南 【免费下载链接】trackerslist Updated list of public BitTorrent trackers 项目地址: https://gitcode.com/GitHub_Trending/tr/trackerslist 还在为BT下载速度慢如蜗牛而烦恼吗?每…...

SEATA分布式事务——AT模式云

简介 AI Agent 不仅仅是一个能聊天的机器人(如普通的 ChatGPT),而是一个能够感知环境、进行推理、自主决策并调用工具来完成特定任务的智能系统,更够完成更为复杂的AI场景需求。 AI Agent 功能 根据查阅的资料,agent的…...

从数据采集到回放验证:ADTF 适配 ROS 的 ADAS 测试实践胃

一、简化查询 1. 先看一下查询的例子 /// /// 账户获取服务 /// /// /// public class AccountGetService(AccountTable table, IShadowBuilder builder) { private readonly SqlSource _source new(builder.DataSource); private readonly IParamQuery_accountQuery b…...

Java中ThreadPoolExecutor 深度剖析

ThreadPoolExecutor 深度剖析(基于Java 21) 这是 JUC 中最核心、最复杂的并发组件之一。以下按维度逐一展开,辅以源码与图示。一、底层实现原理 1.1 核心控制字段:ctl ThreadPoolExecutor 用一个 AtomicInteger 类型的 ctl 字段同…...

OpenCV实战:SimpleBlobDetector参数调优全攻略(附完整代码)

OpenCV实战:SimpleBlobDetector参数调优全攻略(附完整代码) 在工业视觉检测和医学图像分析领域,斑点检测是一项基础但至关重要的任务。想象一下这样的场景:生产线上的零件表面缺陷检测、显微镜下的细胞计数、PCB板焊点…...

旧安卓手机别扔!手把手教你搭建个人隐私安全检测环境(Kali+Metasploit实战)

旧安卓设备重生计划:构建家庭隐私安全实验室的5个关键步骤 那部抽屉里积灰的旧安卓手机,或许是你提升数字安全意识的最佳教具。当科技媒体不断报道数据泄露事件时,大多数人依然对手机应用的权限滥用缺乏直观认知。本文将带你用退役设备搭建一…...

KDE桌面Mac化实战:从Launchpad到全局菜单的完整改造指南

1. 为什么要把KDE桌面改造成macOS风格? 作为一个长期使用Linux的老用户,我完全理解大家对macOS那种简洁优雅界面的向往。但说实话,macOS的封闭性总是让人感觉束手束脚。直到有一天我发现,原来用KDE Plasma可以完美复刻macOS的视觉…...

从Bulk CMOS到先进工艺:Sentaurus TCAD中几何结构与掺杂如何‘捏’出你的Ion和Ioff

从Bulk CMOS到先进工艺:Sentaurus TCAD中几何结构与掺杂如何‘捏’出你的Ion和Ioff 在半导体器件设计中,Ion(导通电流)和Ioff(关断电流)是衡量器件性能的两个关键指标。就像雕塑家通过调整黏土的形状和质地…...

探秘Text2Vec:智能文本处理的新利器

探秘Text2Vec:智能文本处理的新利器 【免费下载链接】text2vec Fast vectorization, topic modeling, distances and GloVe word embeddings in R. 项目地址: https://gitcode.com/gh_mirrors/tex/text2vec Text2Vec是一款强大的R语言文本处理工具包&#xf…...