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

代码随想录算法训练营 Day32 | 动态规划 part05

52. 携带研究材料第七期模拟笔试题目描述小明是一位科学家他需要参加一场重要的国际科学大会以展示自己的最新研究成果。他需要带一些研究材料但是他的行李箱空间有限。这些研究材料包括实验设备、文献资料和实验样本等等它们各自占据不同的重量并且具有不同的价值。小明的行李箱所能承担的总重量是有限的问小明应该如何抉择才能携带最大价值的研究材料每种研究材料可以选择无数次并且可以重复选择。输入描述第一行包含两个整数nv分别表示研究材料的种类和行李所能承担的总重量接下来包含 n 行每行两个整数 wi 和 vi代表第 i 种研究材料的重量和价值输出描述输出一个整数表示最大价值。输入示例4 51 22 43 44 5输出示例10#include iostream #include vector using namespace std; int main(){ int n, bagSize; cin n bagSize; vectorint w(n 1); vectorint v(n 1); // 读入物品的重量和价值您的代码从下标 0 开始读入完全没问题 for(int i 0; i n; i) cin w[i] v[i]; // 1. 定义 DP 数组 // dp[j] 表示容量为 j 的背包能装下的最大价值 vectorint dp(bagSize 1, 0); // 2. 遍历物品 for(int i 0; i n; i){ // 3. 遍历背包容量 —— 核心变化正序遍历 for(int j 0; j bagSize; j){ if(j w[i]){ // 递推公式与 0-1 背包一模一样 // 区别全在遍历顺序上 dp[j] max(dp[j], dp[j - w[i]] v[i]); } } } cout dp[bagSize]; return 0; }总结1. 为什么正序遍历就能实现“无限次使用”以计算dp[5]且当前物品重量w[i] 2为例0-1 背包逆序计算dp[5]时需要用dp[3]。因为逆序dp[3]还没被更新它代表没有放当前物品时的状态。所以当前物品只能放 1 次。完全背包正序计算dp[5]时需要用dp[3]。因为正序dp[3]已经被更新过了。此时的dp[3]已经包含了当前物品所以dp[5] dp[3] v[i]相当于在dp[3]的基础上又放了一次当前物品。这样就实现了物品的重复选取。2. 优化在完全背包中我们可以直接把j的起始点设为w[i]省略掉if判断代码会更简洁for(int i 0; i n; i){ // 直接从 w[i] 开始正序遍历 for(int j w[i]; j bagSize; j){ dp[j] max(dp[j], dp[j - w[i]] v[i]); } }3. 纯背包问题的总结对照表特性0-1 背包完全背包物品数量只能选 1 次可以选无数次一维数组遍历顺序逆序 (j bagSize - w[i])正序 (j w[i] - bagSize)递推公式dp[j] max(dp[j], dp[j-w] v)dp[j] max(dp[j], dp[j-w] v)518. 零钱兑换 II给你一个整数数组coins表示不同面额的硬币另给一个整数amount表示总金额。请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额返回0。假设每一种面额的硬币有无限个。题目数据保证结果符合 32 位带符号整数。class Solution { public: int change(int amount, vectorint coins) { int n coins.size(); // 1. 定义 DP 数组 // dp[j] 表示凑成总金额 j 的硬币组合数 // 【高光细节】这里必须用 uint64_t 或者 long long // 因为组合数会非常大普通的 int 会在 LeetCode 的测试用例中溢出导致错误 vectoruint64_t dp(amount 1, 0); // 2. 初始化 // 凑成金额 0 的组合数是 1即“什么都不选”这一种方法 dp[0] 1; // 3. 状态转移 // 外层遍历物品硬币面额 for(int i 0; i n; i){ // 内层遍历背包容量目标金额 // 完全背包正序遍历从当前硬币面额开始 for(int j coins[i]; j amount; j){ // 递推公式求组合数累加方案数 // dp[j] 不用当前硬币的组合数 使用当前硬币的组合数 dp[j] dp[j - coins[i]]; } } return (int)dp[amount]; } };总结1. 为什么外层必须是物品内层是背包这是求 组合数 和求 排列数 的核心区别。外层物品内层背包 - 求组合数假设coins [1, 5]。当外层循环固定是1时内层循环会把所有包含1的组合算出来如[1,1,1]。当外层循环走到5时它只能加在之前算出的结果后面如[1,1,1,5]。结果5永远在1的后面。算出来的是 组合[1,5] 和 [5,1] 算同一种。外层背包内层物品 - 求排列数假设coins [1, 5]目标金额是 6。当外层循环走到金额6时内层循环先遇到1算出[...1]接着遇到5算出[...5]。如果在某次循环中先凑出了 5下一次金额 6 循环时先遇到 1就会变成[5, 1]。结果1和5的顺序可以颠倒。算出来的是 排列。2.uint64_t的妙用在 C 中int最大只能表示约 21 亿。对于稍微大一点的amount组合数会呈指数级增长。使用uint64_t(无符号 64 位整数) 完美避开了溢出报错最后强转回int返回。3. 复杂度分析时间复杂度O(N×M)N 是硬币种类数M 是目标金额。空间复杂度O(M)。377. 组合总和 Ⅳ给你一个由 不同 整数组成的数组nums和一个目标整数target。请你从nums中找出并返回总和为target的元素排列的个数。题目数据保证答案符合 32 位整数范围。class Solution { public: int combinationSum4(vectorint nums, int target) { int n nums.size(); // 1. 定义 DP 数组 // dp[j] 表示凑成目标和为 j 的排列总数 // 依然使用 uint64_t 防止极端用例下的整型溢出 vectoruint64_t dp(target 1, 0); // 2. 初始化 // 凑成目标和为 0 的排列数是 1什么都不选 dp[0] 1; // 3. 状态转移 // 【核心考点】外层遍历背包目标内层遍历物品数字 for(int j 0; j target; j){ for(int i 0; i n; i){ // 防止数组越界 if(j nums[i]){ // 递推公式与求组合数完全一样累加方案数 dp[j] dp[j - nums[i]]; } } } return dp[target]; } };总结1. 题目解析为什么叫“组合”却求“排列”LeetCode 这道题的名字极具误导性。题目描述中说“不同的序列被视为不同的组合”。在正常的数学定义中[1, 3]和[3, 1]是同一种组合但属于两种不同的排列。题目既然把不同顺序算作不同结果那么它本质上求的就是 排列数。2. 遍历顺序外层j内层i代码求排列外层是target。当我们要计算dp[6]时我们会依次把nums里的数放进去试。如果nums [1, 2, 3]计算dp[6]时先加dp[5]意味着排列的最后一步是 1再加dp[4]意味着排列的最后一步是 2再加dp[3]意味着排列的最后一步是 3效果1可以在前面也可以在后面元素的先后顺序被完全保留了算出来的是 排列数。上一题代码求组合外层是nums。当外层固定是1时所有的1都只能被最先放入背包。效果1永远排在2和3的前面打乱了原始顺序算出来的是 组合数。公式都是dp[j] dp[j - nums[i]]仅仅是for循环换了个位置结果就截然不同这就是动态规划的美丽与恐怖之处。3.if(j nums[i])的必要性在求组合数时我们可以直接把内层循环写成for(int j coins[i]; j amount; j)省去if判断。但在求排列数时不能这么写。因为外层循环是在遍历j而nums[i]在内层每次i变化时nums[i]都不同所以必须在内部用if来做越界保护。您的处理非常严谨。57. 爬楼梯第八期模拟笔试题目描述假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬至多m (1 m n)个台阶。你有多少种不同的方法可以爬到楼顶呢注意给定 n 是一个正整数。输入描述输入共一行包含两个正整数分别表示n, m输出描述输出一个整数表示爬到楼顶的方法数。输入示例3 2输出示例3#include iostream #include vector using namespace std; int main(){ int n, m; cin n m; // n: 目标台阶数(背包容量), m: 一次最多爬的步数(物品范围) // 1. 定义 DP 数组 // dp[j] 表示爬到第 j 阶有多少种不同的排列方法 vectorint dp(n 1, 0); // 2. 初始化 // 爬到第 0 阶起点有一种方法就是原地不动 dp[0] 1; // 3. 状态转移 // 【核心】求排列数外层必须是背包容量台阶 j内层是物品步数 i for(int j 1; j n; j){ for(int i 1; i m; i){ if(j i){ // 递推公式累加方案数 // 爬到 j 阶的方法数 爬到 j-i 阶的方法数 dp[j] dp[j - i]; } } } cout dp[n]; return 0; }总结1. 为什么必须是“外层 j内层 i”如果反过来写外层i内层j比如m2外层i1时算出的全是以1开头的序列如1,1,1...或1,2,1...。外层i2时算出的全是以2开头的序列如2,1,1...。这就变成了 组合数先走 1 后走 2和先走 2 后走 1 被当成同一种。但爬楼梯显然讲究顺序先跨 1 步再跨 2 步和先跨 2 步再跨 1 步是两种不同的爬法所以必须用 外层 j 内层 i 来求排列数。2. 与纯背包题的细微差别纯背包题给你一个数组如[1, 5, 2]数组里的元素是固定的可能无序。本题隐含的数组是[1, 2, 3, ..., m]这是一个连续递增的序列。但不管物品是乱序还是连续递增只要是求排列数模板就绝对不能变。

相关文章:

代码随想录算法训练营 Day32 | 动态规划 part05

52. 携带研究材料(第七期模拟笔试) 题目描述 小明是一位科学家,他需要参加一场重要的国际科学大会,以展示自己的最新研究成果。他需要带一些研究材料,但是他的行李箱空间有限。这些研究材料包括实验设备、文献资料和实…...

VibeVoice-TTS商业应用:有声读物自动化生产解决方案

VibeVoice-TTS商业应用:有声读物自动化生产解决方案 1. 引言 1.1 有声读物行业现状 有声读物市场近年来呈现爆发式增长,全球市场规模已突破百亿美元。传统有声读物制作面临三大挑战: 制作成本高:专业配音员录制每小时内容成本…...

AI头像生成器应用案例:为MySQL数据库用户自动生成统一风格头像

AI头像生成器应用案例:为MySQL数据库用户自动生成统一风格头像 1. 项目背景与价值 在数字化时代,用户头像已经成为各类应用不可或缺的元素。无论是社交平台、企业管理系统还是在线教育平台,个性化的用户头像都能显著提升用户体验。然而&…...

大模型中的Function_call与Agent:从功能调用到智能决策的演进

1. 从工具到管家:理解Function_call与Agent的本质区别 第一次接触大模型开发时,我常常分不清什么时候该用Function_call,什么时候需要设计Agent。直到有次开发智能点餐系统,才真正明白两者的差异。想象你在餐厅点单:当…...

Qwen3-0.6B-FP8部署教程:vLLM服务健康检查(llm.log)、Chainlit端口映射与CORS配置

Qwen3-0.6B-FP8部署教程:vLLM服务健康检查、Chainlit端口映射与CORS配置 1. 开篇:为什么你需要这篇教程? 如果你正在尝试部署一个轻量级的AI模型,比如Qwen3-0.6B-FP8,并且希望它能稳定运行,还能通过一个漂…...

中国大陆市场已成为达美乐比萨全球第三大国际市场

美通社消息:2026年第一季度,在复杂多变的消费环境下,达势股份-达美乐中国持续深耕中国这一仍具广阔增长空间的比萨市场,依托经市场验证的4D战略,即高质量的门店开发(Development)、高质价比的美味比萨(Delicious Pizza…...

我实测过的9个AI Agent Skills(用过就再也离不开)

智能体技能正成为打造实用AI智能体的全新黄金标准,但没人告诉你这个生态系统究竟有多混乱。找到安全又好用的技能就像碰运气;大多数仓库看起来惊艳无比……可一上手就原形毕露。我深有体会,因为我翻遍了几十个仓库。我一头扎进这个领域&#…...

弱网测试工具全攻略:从原理到实战应用

1. 弱网测试的核心原理与价值 第一次在地铁里刷不出健康码时,我才真正理解弱网测试的重要性。当时看着手机屏幕上不断转圈的小图标,后背都急出了汗。这种真实场景下的网络波动,正是我们需要在实验室里模拟复现的关键场景。 弱网本质上是指网络…...

交警机器人上岗常州护航苏超揭幕战;管理者敬业度已不再高于普通员工 | 美通社一周热点简体中文稿

美通社每周发布数百上千篇中文企业资讯,想看完所有稿件可能很困难。以下是我们对过去一周不容错过的主要企业稿件进行的归纳,帮助记者和读者们及时了解一周发布的热门企业资讯。管理者敬业度已不再高于普通员工2025年,全球员工敬业度降至20%&…...

HunyuanVideo-Foley部署指南:系统盘50G+数据盘40G磁盘规划最佳实践

HunyuanVideo-Foley部署指南:系统盘50G数据盘40G磁盘规划最佳实践 1. 镜像概述与核心特性 HunyuanVideo-Foley是一款专为视频生成与音效生成任务定制的私有部署镜像,基于RTX 4090D 24GB显存显卡和CUDA 12.4深度优化。本镜像内置完整的运行环境和加速库…...

AI读脸术扩展思路:如何接入表情识别等更多功能

AI读脸术扩展思路:如何接入表情识别等更多功能 1. 引言 1.1 人脸属性分析的技术演进 人脸属性识别技术已经从最初的单一性别识别发展到如今的多维度分析。现代系统能够同时检测年龄、性别、表情、眼镜佩戴情况等多种属性,为商业智能、人机交互等领域提…...

常量和变量详细讲解

在 Python 里,变量和常量都是“名字”,本质上都是给某个对象起的标识符。 区别主要不在语法强制,而在使用约定和语义目的。1. 什么是变量变量就是一个可以指向某个值的名字。例如:name "Alice" age 18 price 9.9这里…...

3DGS渲染核心:手把手拆解从3D高斯到2D椭圆的投影变换(附GLM列主序避坑指南)

3DGS渲染核心:手把手拆解从3D高斯到2D椭圆的投影变换(附GLM列主序避坑指南) 在实时渲染领域,3D高斯分布(3D Gaussian Splatting)技术正逐渐成为新一代点云渲染的标准方案。这项技术通过将三维空间中的点云表…...

PyTorch 2.8镜像多场景落地:覆盖大模型训练/视频生成/推理API/私有部署

PyTorch 2.8镜像多场景落地:覆盖大模型训练/视频生成/推理API/私有部署 1. 开箱即用的深度学习环境 PyTorch 2.8深度学习镜像是一个经过深度优化的通用AI开发环境,专为现代深度学习工作负载设计。这个镜像最吸引人的特点是它已经帮你解决了环境配置这个…...

微信小程序的家园社区生活事务小区物业报修缴费

目录同行可拿货,招校园代理 ,本人源头供货商功能模块概述物业报修功能缴费功能设计技术实现要点扩展功能建议项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 功能模块概述 微信小程序的…...

Llama-3.2V-11B-cot保姆级教学:GPU温度监控与过热降频应对方案

Llama-3.2V-11B-cot保姆级教学:GPU温度监控与过热降频应对方案 1. 项目背景与温度监控的重要性 Llama-3.2V-11B-cot作为一款基于Meta多模态大模型开发的高性能视觉推理工具,在双卡RTX 4090环境下运行时,GPU温度管理是确保稳定性的关键因素。…...

Halcon中Contour XLD的两种可视化方法对比及三通道图像处理技巧

1. Contour XLD可视化基础与两种方法对比 在Halcon机器视觉开发中,Contour XLD(亚像素级轮廓)的处理和可视化是常见需求。很多刚接触Halcon的朋友经常困惑:为什么我提取的轮廓无法直接保存到图像文件?这就要从XLD的本质…...

Z-Image Turbo CPU Offload配置教程:小显存设备高效运行方案

Z-Image Turbo CPU Offload配置教程:小显存设备高效运行方案 1. 引言 还在为小显存设备运行AI绘图而烦恼吗?Z-Image Turbo的CPU Offload功能正是为你量身打造的解决方案。这个基于Gradio和Diffusers构建的高性能AI绘图Web界面,专门针对Z-Im…...

DeOldify GPU算力优化教程:显存占用控制与推理速度提升技巧

DeOldify GPU算力优化教程:显存占用控制与推理速度提升技巧 1. 项目简介与优化价值 DeOldify是一个基于深度学习技术的黑白图像上色工具,它使用U-Net架构结合ResNet编码器来实现高质量的图像色彩还原。虽然这个工具使用起来很简单,但在实际…...

深入解析:使用Apache POI与Hutool高效提取WPS Excel中的嵌入式图片

1. 为什么需要提取Excel中的嵌入式图片? 在日常工作中,我们经常会遇到需要处理包含图片的Excel文件。比如电商平台的产品数据报表里嵌入了商品图片,财务系统中保存了带有签名的报销单,或者数据分析报告里包含了图表截图。这些图片…...

推荐几款适合送人的红茶,体面又有心意

送礼选红茶,既要品质过硬、口感温润,也要包装大气、寓意美好,方能传递真挚心意。红茶性温养胃,适配各类人群,礼盒装更是兼顾格调与实用性,无论是送长辈、领导,还是赠亲友、同事,都是…...

终极语言学习革命:如何通过肌肉记忆训练重塑你的编程与英语能力?

终极语言学习革命:如何通过肌肉记忆训练重塑你的编程与英语能力? 【免费下载链接】qwerty-learner 为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers …...

我在 Cursor 里接入了 Claude Code,三种方式实测告诉你哪个最好用

我在 Cursor 里接入了 Claude Code,三种方式实测告诉你哪个最好用 Cursor 用了快一年,日常写代码够用。但遇到跨文件重构、从零搭架构这类活,它的 Agent 模式经常半途而废——改了三个文件,漏掉第四个的类型定义,然后整…...

Qwen3.5-2B部署教程:阿里云ACK集群中Qwen3.5-2B服务化封装与API网关对接

Qwen3.5-2B部署教程:阿里云ACK集群中Qwen3.5-2B服务化封装与API网关对接 1. 引言 Qwen3.5-2B是阿里云推出的轻量化多模态基础模型,属于Qwen3.5系列的小参数版本(20亿参数)。这款模型主打低功耗、低门槛部署特性,特别…...

Qwen3-14B私有部署镜像Java面试题智能解析与模拟面试

Qwen3-14B私有部署镜像Java面试题智能解析与模拟面试 1. 为什么Java开发者需要AI面试助手 Java作为企业级开发的主流语言,技术栈庞大且更新迭代快。传统的面试准备方式存在几个明显痛点:首先,手动整理海量面试题耗时费力;其次&a…...

宏与脚本语言,应用程序的应用实例

除了 VBA 和 VBScript,脚本语言与应用程序的深度结合,几乎存在于所有你想象得到的专业软件领域。无论是进行专业绘图、处理音频视频、进行科学计算,还是控制外部设备,软件大多会提供一种自动化的能力,而实现这种能力的…...

HUNYUAN-MT 7B翻译终端与微信小程序开发结合:实现实时对话翻译工具

HUNYUAN-MT 7B翻译终端与微信小程序开发结合:实现实时对话翻译工具 你有没有遇到过这样的场景?在国外旅行,想和当地人交流却语言不通;或者工作中需要和外国同事沟通,但双方语言有障碍。这时候,一个能装在手…...

Intv_AI_MK11 前端设计辅助:基于 UI/UX 原则的交互方案生成

Intv_AI_MK11 前端设计辅助:基于 UI/UX 原则的交互方案生成 1. 引言:当AI遇见前端设计 想象一下这样的场景:产品经理刚开完需求评审会,设计师正在构思界面原型,前端工程师准备开始编码。这时,一个共同的挑…...

Obsidian 快捷键全攻略 —— 打造个性化高效笔记流

1. Obsidian快捷键:你的数字笔记加速器 第一次打开Obsidian时,我被它简洁的界面和强大的功能所吸引,但真正让我效率翻倍的,是那些隐藏在键盘上的秘密武器——快捷键。作为一个重度笔记用户,我试过从记事本到专业笔记软…...

如何用GetQzonehistory实现QQ空间数据备份?3步永久保存你的数字记忆

如何用GetQzonehistory实现QQ空间数据备份?3步永久保存你的数字记忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 在数字时代,我们的青春记忆越来越多地存储在…...