news 2026/6/15 17:26:02

力扣打卡每日一题————零钱兑换

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
力扣打卡每日一题————零钱兑换

零钱兑换问题

一、问题描述

题目要求

给定不同面额的硬币coins和一个总金额amount,编写一个函数来计算可以凑成总金额所需的最少的硬币个数。如果没有任何一种硬币组合能组成总金额,返回-1

示例

  • 输入:coins = [1,2,5], amount = 11

  • 输出:3(解释:11 = 5 + 5 + 1,最少需要 3 枚硬币)

  • 输入:coins = [2], amount = 3

  • 输出:-1(解释:无法用面额 2 的硬币凑出 3)

核心难点

  1. 需找到 “最少硬币数”,而非所有组合数;
  2. 需处理 “无法凑出金额” 的边界情况;
  3. 避免数组越界、数值溢出等编码错误。

二、解题思路:动态规划(DP)

1. 状态定义

定义dp[i]表示:凑成总金额i所需的最少硬币数量

2. 初始化

  • 基准条件:dp[0] = 0,因为凑 0 元不需要任何硬币。
  • 其他状态:初始化dp[i] = amount + 1amount+1是一个 “大于最大可能值” 的数,代表 “初始不可达”。最大可能值是amount(全用 1 元硬币),因此amount+1可标记为 “未更新”。

3. 状态转移

对于每个金额i(从 1 到amount),遍历所有硬币面额coin

  • coin <= i(当前硬币面额不超过目标金额),则:dp[i] = min(dp[i], dp[i - coin] + 1)
  • 解释:dp[i - coin]是凑出i - coin元的最少硬币数,加 1 枚当前硬币即可凑出i元,取所有可能中的最小值。

4. 结果判断

  • dp[amount] > amount:说明始终未更新,无法凑出金额,返回-1
  • 否则:返回dp[amount](最少硬币数)。

三、完整代码实现

class Solution { public: int coinChange(vector<int>& coins, int amount) { vector<int> dp(amount + 1, amount + 1); dp[0] = 0; for (int i = 1; i <= amount; ++i) { for (int j = 0; j < coins.size(); ++j) { if (coins[j] <= i) { dp[i] = min(dp[i], dp[i - coins[j]] + 1); } } } return dp[amount] > amount ? -1 : dp[amount]; } };

四、复杂度分析

  • 时间复杂度O(amount * len(coins))外层循环遍历amount个金额,内层循环遍历所有硬币,总次数为两者乘积。
  • 空间复杂度O(amount)仅需维护一个大小为amount + 1的 dp 数组,属于线性空间。

五、总结

问题的核心是动态规划的状态转移思想:将 “凑金额 i” 的大问题,拆解为 “凑金额 i-coin” 的小问题

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 12:16:46

Gemini API 终极教程:5分钟快速掌握Python异步编程利器

Gemini API 终极教程&#xff1a;5分钟快速掌握Python异步编程利器 【免费下载链接】Gemini-API ✨ An elegant async Python wrapper for Google Gemini web app 项目地址: https://gitcode.com/gh_mirrors/gem/Gemini-API Gemini API教程为您带来一款优雅的异步Python…

作者头像 李华
网站建设 2026/6/10 17:33:27

ImageKnife终极指南:从入门到精通OpenHarmony图片加载技术

还在为OpenHarmony应用中的图片加载卡顿、内存溢出而头疼吗&#xff1f;ImageKnife作为OpenHarmony生态中最专业的图片加载库&#xff0c;将彻底解决你的性能痛点。本文将带你从零基础到高级应用&#xff0c;全面掌握这一强大的图片处理工具。 【免费下载链接】ImageKnife 专门…

作者头像 李华
网站建设 2026/6/15 6:45:16

Livewire框架终极指南:3分钟快速上手动态Laravel应用开发

Livewire框架终极指南&#xff1a;3分钟快速上手动态Laravel应用开发 【免费下载链接】livewire livewire&#xff1a;这是Laravel Livewire的一个官方示例项目&#xff0c;适合学习如何使用Livewire组件来构建动态网页。特点包括实时更新、易于测试、与Laravel框架集成良好等。…

作者头像 李华
网站建设 2026/6/15 14:04:33

GSV6127EA@ACP#6127EA产品规格详解及产品应用分享

GSV6127EA 参数规格及产品应用详细解析一、产品概述GSV6127EA 是基石酷联微电子&#xff08;GScoolink&#xff09;推出的高集成度 Type-C/DisplayPort 1.4 转 MIPI CSI-2 专用转换器&#xff0c;核心定位为 “高清信号桥接 音频提取 嵌入式控制” 一体化解决方案。其通过集成…

作者头像 李华
网站建设 2026/6/15 3:58:39

Hermes-4 14B:混合推理与低拒绝率重构企业级AI应用新范式

Hermes-4 14B&#xff1a;混合推理与低拒绝率重构企业级AI应用新范式 【免费下载链接】Hermes-4-14B 项目地址: https://ai.gitcode.com/hf_mirrors/NousResearch/Hermes-4-14B 导语 2025年开源大模型领域再添强将——Nous Research推出的Hermes-4 14B以"混合推理…

作者头像 李华
网站建设 2026/6/14 14:31:33

5个常见问题解析:让您在树莓派上轻松部署Windows系统

5个常见问题解析&#xff1a;让您在树莓派上轻松部署Windows系统 【免费下载链接】WOA-Deployer-Rpi WOA Deployer for Raspberry Pi 项目地址: https://gitcode.com/gh_mirrors/wo/WOA-Deployer-Rpi 您是否想过在树莓派上运行完整的Windows操作系统&#xff1f;WOA Dep…

作者头像 李华