算法322. 零钱兑换

题目

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

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

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

示例 1:

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

输出:3

解释:11 = 5 + 5 + 1

示例 2:

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

输出:-1

示例 3:

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

输出:0

题解

python 复制代码
class Solution:
    def coinChange(self, coins: List[int], amount: int) -> int:
        @cache
        # 完全背包问题
        # dfs(i, c) = 使用硬币种类 coins[0], coins[1], ..., coins[i]来凑出恰好金额c所需的最少硬币数量
        # i:当前可以考虑的硬币种类的最大索引
			# i = 0 表示只能使用第一种硬币 coins[0]
			# i = 2 表示可以使用前三种硬币 coins[0], coins[1], coins[2]

		# c:需要凑出的剩余目标金额
        def dfs(i:int,c:int)->int:
        	# 没有硬币可用(i < 0),但金额也刚好为0,说明之前的硬币选择已经完美凑出了目标金额
            if i < 0:
                return 0 if c == 0 else inf
            # 不选该硬币
            if c < coins[i]:
                return dfs(i-1,c)
            
            # 不选 vs 选
            # 这里覆盖了没有任何一种硬币组合能组成总金额的情况,此时这里会返回inf
            return min(dfs(i-1,c),dfs(i,c-coins[i])+1)
        
        ans = dfs(len(coins) - 1,amount)
        return ans if ans<inf else -1

复杂度分析

  • 时间复杂度:O(n⋅amount),其中 n 为 coins 的长度。
  • 空间复杂度:O(n⋅amount)。
相关推荐
CoovallyAIHub14 分钟前
MSD-DETR:面向机车弹簧检测的可变形注意力Detection Transformer
算法·架构
CoovallyAIHub18 分钟前
不改权重、不用训练!BEM用背景记忆抑制固定摄像头误检,YOLO/RT-DETR全系有效
算法·架构·github
Struggle_975523 分钟前
算法知识-从递归入手三维动态规划
算法·动态规划
yuan1999728 分钟前
使用模糊逻辑算法进行路径规划(MATLAB实现)
开发语言·算法·matlab
不才小强32 分钟前
线性表详解:顺序与链式存储
数据结构·算法
CoovallyAIHub32 分钟前
上交+阿里 | Interactive ASR:Agent框架做语音识别交互纠错,1轮交互语义错误率降57%
算法·架构·github
Aaron158843 分钟前
8通道测向系统演示科研套件
人工智能·算法·fpga开发·硬件工程·信息与通信·信号处理·基带工程
计算机安禾1 小时前
【数据结构与算法】第42篇:并查集(Disjoint Set Union)
c语言·数据结构·c++·算法·链表·排序算法·深度优先
吃着火锅x唱着歌1 小时前
LeetCode 150.逆波兰表达式求值
linux·算法·leetcode
YuanDaima20481 小时前
二分查找基础原理与题目说明
开发语言·数据结构·人工智能·笔记·python·算法