【leetcode100】零钱兑换Ⅱ

1、题目描述

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

请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0

假设每一种面额的硬币有无限个。

题目数据保证结果符合 32 位带符号整数。

示例 1:

复制代码
输入:amount = 5, coins = [1, 2, 5]
输出:4
解释:有四种方式可以凑成总金额:
5=5
5=2+2+1
5=2+1+1+1
5=1+1+1+1+1

示例 2:

复制代码
输入:amount = 3, coins = [2]
输出:0
解释:只用面额 2 的硬币不能凑成总金额 3 。

示例 3:

复制代码
输入:amount = 10, coins = [10] 
输出:1

2、初始思路

2.1 思路

每个硬币可以重复取,这是一道完全背包问题。递推公式为:

复制代码
dp[j] += dp[j-coin]

2.2 代码

复制代码
class Solution:
    def change(self, amount: int, coins: List[int]) -> int:
        dp = [0] * (amount+1)
        dp[0] = 1
        for coin in coins:
            for j in range(coin, amount+1):
                dp[j] += dp[j-coin]
        return dp[amount]
相关推荐
肖永威13 小时前
Python多业务并行计算框架插件化演进:从硬编码到动态注册
python·插件化·并行计算·动态注册
yz_aiks13 小时前
Linux Jar包配置Systemd自启动实战:从排查到配置全流程
linux·python·jar·自启动·systemd
徐小夕13 小时前
万字长文!千万级文档 RAG 知识库系统落地实践
前端·算法·github
不知名的老吴13 小时前
线程的生命周期之线程“插队“
java·开发语言·python
akunkuntaimei13 小时前
2026年高考数学各省真题及答案(完整版)
算法·高考
Hello:CodeWorld14 小时前
C 风格变参 vs C++ 变参模板:核心区别与选型指南
c语言·c++·算法
xsc69967514 小时前
从零搭建大模型与智能体平台 - 完整技术详解
python
8Qi815 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
无风听海16 小时前
多租户系统中的 OIDC:Discovery 端点与联合登录的深度实践
后端·python·flask
CTA终结者16 小时前
期货量化主力换月程序怎么移仓:天勤 underlying_symbol 与任务切换
python·区块链