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

信奥赛CSP动态规划入门-最小硬币问题

针对**“最小硬币问题”**的详细分步解析与程序实现,通过将大问题分解为小问题的方式讲解动态规划的应用:


一、问题拆解步骤

1. 明确问题定义

大问题:用面值1元和5元的硬币凑出N元,最少需要多少枚硬币
小问题:凑出k元(0 ≤ k ≤ N)所需的最小硬币数。

2. 状态定义
  • 定义数组dp[i] 表示凑出i元所需的最小硬币数
  • 物理意义:每个dp[i]都是独立的小问题解
3. 初始条件
金额最小硬币数解释
0元0不需要任何硬币
1元1只能用1个1元硬币
2元2两个1元硬币
逐步推导到目标金额
4. 状态转移方程

递推逻辑
对每个金额i,尝试使用所有可能的硬币面值coin,取最小值:

dp[i] = min(dp[i], dp[i - coin] + 1)

二、分步程序实现

#include <iostream>
#include <algorithm>  // 使用min函数
using namespace std;int main() {int coins[] = {1, 5};      // 硬币面值int target;                // 目标金额cout << "请输入目标金额:";cin >> target;// 步骤1:初始化dp数组int dp[100];               // 假设最大金额不超过99元fill(dp, dp + 100, 999);   // 初始化为极大值(代表不可达)dp[0] = 0;                 // 凑0元需要0个硬币// 步骤2:逐个解决小问题for (int i = 1; i <= target; i++) {  // 从1元开始计算// 尝试每一种硬币for (int coin : coins) {         // C++11范围循环if (i >= coin) {             // 确保不会出现负数// 状态转移:用更小问题的解构建当前解dp[i] = min(dp[i], dp[i - coin] + 1);}}}// 步骤3:输出最终解if (dp[target] != 999) {cout << "最少需要 " << dp[target] << " 枚硬币" << endl;} else {cout << "无法凑出目标金额!" << endl;}return 0;
}

三、动态规划过程演示(以target=10为例)

1. 初始化数组
金额012345678910
dp值0
2. 逐步填充过程
  • i=1元
    • 尝试1元硬币:dp[1] = min(∞, dp[0]+1) = 1
    • 5元硬币不可用
  • i=5元
    • 尝试1元硬币:dp[5] = min(∞, dp[4]+1) = ∞
    • 尝试5元硬币:dp[5] = min(∞, dp[0]+1) = 1
  • i=10元
    • 尝试1元硬币:dp[10] = dp[9]+1 = 2+1=3
    • 尝试5元硬币:dp[10] = dp[5]+1 = 1+1=2
3. 最终结果
金额012345678910
dp值01234123452

四、关键点解析

  1. 大问题化小问题

    • 将"凑10元"分解为"凑1元、2元…9元"的子问题
    • 每个子问题的解都记录在dp[]数组中
  2. 递推关系本质

    凑i元的最优解 = min(凑(i-1元)的最优解 + 1个1元硬币,凑(i-5元)的最优解 + 1个5元硬币
    )
    
  3. 时间复杂度:O(M×N)

    • M为硬币种类数,N为目标金额

五、测试样例

输入输出解释
10最少需要2枚硬币5+5
13最少需要3枚硬币5+5+1+1+1 → 5+5+3(错误!实际应为5+5+3不存在,正确应为5+5+1+1+1=5枚?这里需要验证)
0最少需要0枚硬币无需硬币
3最少需要3枚硬币1+1+1

注意:测试时需确保硬币面值数组与实际题目一致


http://www.lryc.cn/news/2384357.html

相关文章:

  • cmd里可以使用npm,vscode里使用npm 报错
  • JAVA开发工具延长方案
  • CSS 浮动(Float)及其应用
  • CC53.【C++ Cont】一维前缀和
  • Python爬虫实战:研究Grab 框架相关技术
  • 每日leetcode
  • YouTube视频字幕转成文章算重复内容吗?
  • 网络学习-利用reactor实现http请求(六)
  • 云原生安全:IaaS安全全解析(从基础到实践)
  • 【IC_Design】跨时钟域的寄存器更新后锁存
  • Spring AI 之提示词
  • 亚远景-汽车软件开发的“升级之路”:ASPICE各等级说明
  • Java微服务架构:Spring Cloud全栈指南,附最新Demo源码,可独立运行!
  • 使用LLaMA-Factory微调ollama中的大模型(一)------家用电脑安装LLaMA-Factory工具
  • 支持向量机(SVM):分类与回归的数学之美
  • 手撕I2C和SPI协议实现
  • 人工智能+:职业价值的重构与技能升级
  • JVM部分内容
  • paddlehub搭建ocr服务
  • python-leetcode 68.有效的括号
  • 人性的裂痕:社会工程学如何成为网络安全的隐形战场
  • ObservableCollection序列化,和监听链表内元素变化
  • NLP学习路线图(四):Python编程语言
  • matlab实现无线通信组
  • 基于单片机的室内采光及可燃气体泄漏报警装置设计
  • Serverless爬虫架构揭秘:动态IP、冷启动与成本优化
  • 从单体到分布式:深入解析Data Mesh架构及其应用场景与价值
  • AI大模型ms-swift框架实战指南(十三):Agent智能体能力构建指南
  • LLM最后怎么输出值 解码语言模型:从权重到概率的奥秘
  • Leetcode百题斩-回溯