322. 零钱兑换 ——【Leetcode每日一题】
创始人
2025-05-28 23:14:13
0

322. 零钱兑换

给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1

你可以认为每种硬币的数量是无限的。

322. 零钱兑换

示例 1:

输入:coins = [1, 2, 5], amount = 11
输出:3
解释:11 = 5 + 5 + 1

示例 2:

输入:coins = [2], amount = 3
输出:-1

示例 3:

输入:coins = [1], amount = 0
输出:0

提示:

  • 1<=coins.length<=121 <= coins.length <= 121<=coins.length<=12
  • 1<=coins[i]<=231−11 <= coins[i] <= 2^{31} - 11<=coins[i]<=231−1
  • 0<=amount<=1040 <= amount <= 10^40<=amount<=104

思路:(动态规划)

此问题属于 0-1背包 的 完全背包 ,解法和 0-1背包类似:
0 - 1背包问题(万能统一代码)

定义一个二维数组dp 存储所需硬币个数,其中 dp[i][j] 表示前 i 个硬币 可以凑成总金额 为 j 所需最少的硬币个数

  • 每种硬币的数量是无限的,所以可以重复使用
  • 状态转移方程为:
    dp[i][j]=min(dp[i−1][j],dp[i][j−coins[i]]+1)dp[i][j] = min(dp[i - 1][j], dp[i ][j - coins[i]] + 1)dp[i][j]=min(dp[i−1][j],dp[i][j−coins[i]]+1)

在这里插入图片描述

观察前 i 个硬币的状态仅与前 i-1 个硬币的状态有关,因此可以将 dp 定义为一维数组,其中 dp[j] 既可以表示 dp[i-1][j] 也可以表示 dp[i][j]:状态转移方程为:
dp[j]=min(dp[j],dp[j−coins[i]]+1)dp[j] = min(dp[j], dp[j - coins[i]] + 1)dp[j]=min(dp[j],dp[j−coins[i]]+1)

代码:(Java)

import java.util.Arrays;public class CoinChange {public static void main(String[] args) {// TODO Auto-generated method stubint[] coins = {1, 2, 5};int amount = 11;System.out.println(coinChange(coins, amount));}public static int coinChange(int[] coins, int amount) {if(amount == 0) {return 0;}int[] dp = new int[amount + 1];for(int i = 0; i < coins.length; i++) {if(coins[i] > amount) {continue;}dp[coins[i]] = 1;for(int j = coins[i] + 1; j <= amount; j++) {if(dp[j - coins[i]] != 0 && (dp[j] == 0 || dp[j] > dp[j - coins[i]] + 1)) {dp[j] = dp[j - coins[i]] + 1;}}}return dp[amount] == -1 ? 0 : dp[amount];}
}

运行结果:

在这里插入图片描述

复杂度分析:

  • 时间复杂度:O(len∗amount)O(len * amount)O(len∗amount), lenlenlen 为数组 coinscoinscoins 的长度,amountamountamount 为要凑成的总金额。
  • 空间复杂度:O(amount)O(amount)O(amount) ,需要开辟一个一维数组 dp , 长度为amount+1amount + 1amount+1 ,amountamountamount 为要凑成的总金额。

注:仅供学习参考!

题目来源:力扣。

相关内容

热门资讯

FIBA期待杨瀚森表现 最新实... 北京时间6月25日消息,FIBA国际篮联公布了最新一期世界杯预选赛亚太区球队实力榜,中国男篮排在澳大...
收评:创业板指放量反弹涨2.8... 市场冲高回落后,再度震荡拉升。黄白线分化明显,权重股走势较强。量能明显放大,沪深两市成交额3.59万...
巨头财报引爆A股存储芯片板块,... 当地时间6月24日美股盘后, 美光科技(MU.US)公布截至5月31日的2026财年第三财季财报,业...
银行、消金公司助贷余额增速不得... 近日,中国证券报记者从多位业内人士处独家获悉,5月以来,多地金融监管部门对部分中小银行、消金公司下达...
朱鸿接任陈航,担任钉钉科技有限... 消费日报-今朝新闻讯 天眼查显示,6月23日,钉钉科技有限公司发生工商变更,陈航卸任法定代表人、董事...
3日累跌超20%,德创环保:公... 6月25日, 德创环保(603177.SH)公告,公司股票于2026年6月23日、6月24日和6月2...
北京发布2026年第七轮拟供商... 央广网北京6月25日消息(记者门庭婷)6月25日,北京市规划和自然资源委员会网站发布了2026年第七...
开放麦 | 启明创投胡奇:从A... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
腾讯孙忠怀:在行业转身处 6月24日,2026腾讯视频年度发布在上海举行。腾讯公司副总裁、腾讯在线视频董事长孙忠怀以《在行业转...
加息,突变!美联储,重磅传来!... 美联储政策路径突生变数。 美国商务部经济分析局最新公布的数据显示,5月个人消费支出(PCE)物价指数...
6月合肥上门收金必看!5步避坑... 2026年6月,合肥黄金市场持续高位运行,不少市民翻出家里闲置的旧金饰、投资金条想变现,上门回收因为...
潮汕女富豪挂帅后加码液冷!祥鑫... 潮汕女强人,带着百亿公司加码液冷散热。 6月24日晚间,祥鑫科技(002965.SZ)公告称,公司董...
马斯克向太空要电,GobiX ... 一场关于「去哪里找电」的全球竞赛,正在朝两个方向展开。 作者|周永亮 编辑| 郑玄 「太空光伏是不是...
原料药行业陷入周期低谷 有药企... 每经记者|许立波 每经编辑|魏文艺 “过完年到现在,我们整个团队每个月都在出差,跑遍了亚非拉、欧美市...
家门口筛查白内障!永顺泽家镇暖... 大众卫生报·新湖南客户端6月25日讯(通讯员 彭雪姣)为切实解决辖区老年性白内障患者异地就医奔波、就...
终于等到!油价马上再大跌,这个... 点击添加图片描述(最多60个字) 编辑 各位车主朋友,好消息接二连三! 继6月18日油价大幅下调...
丈量出海新路 世界酒庄影响力指... 长期以来,全球酒庄评价体系由西方机构主导,且大多局限于单一酒种、单一评价维度,这一局面正逐渐被打破。...
峰瑞资本创始合伙人李丰:从资本... “2026年,创投圈的浪潮再次翻涌:AI从技术概念走进产业深水区,硬科技创业从“小众赛道” 变成“主...
原创 A... 迈向成熟,还有茁壮成长的机会。 作者 | 方璐 编辑丨于婞 来源 | 野马财经 2026年6月21日...
为企业解锁出海新通道!亚太中小... 6月24日下午,作为2026年APEC中小企业工商论坛的重要组成部分,亚太中小企业国际化合作发展论坛...