动态规划——零钱兑换(python)

思路:

dpi定义为,求能够凑成数i所需要的最少个数为dpi。状态转移:dpi=min(dpi-coins\[i]+1,dpi。这里是求个数!求个数!求个数! 所以这里是由上个状态加数字1转移,这里要好好理解。

复制代码
def coinsChange(coins,n):
    #求能凑成i的最少个数
    dp=[float('inf')]*(n+1)
    dp[0]=0
    for i in range(1,n+1):
        for j in coins:
            if i>=j:
                dp[i]=min(dp[i-j]+1,dp[i])
    if dp[n]==float('inf'):
        return -1
    return dp[n]


def main():
    coins=list(map(int,input().split()))
    n=int(input())
    res=coinsChange(coins,n)
    print(res)

if __name__=="__main__":
    main()
相关推荐
麻雀飞吧4 分钟前
期货多合约策略目标持仓怎么更新才不乱
python·区块链
Cthy_hy15 分钟前
拓扑排序超详解:原理 + Kahn 贪心算法
python·算法·贪心算法
LSssT.25 分钟前
【01】Python 机器学习
开发语言·python
为爱停留35 分钟前
给智能体装上「刹车」:中断(Interrupts)与人工审批全解析
python
l1t1 小时前
DeepSeek总结的使用实体-组件-系统和基于存在性处理进行Python编程39-40
开发语言·python
8Qi81 小时前
LeetCode 494:目标和(Target Sum)—— 题解 ✅
算法·leetcode·职场和发展·动态规划·01背包
曾阿伦1 小时前
Python 搭建简易HTTP服务
开发语言·python·http
MIUMIUKK1 小时前
从语法层面,看懂 Python 的特殊处
java·开发语言·python
着迷不白1 小时前
第一部分:认识python
开发语言·python
hujinyuan201602 小时前
2026年3月 中国电子学会青少年软件编程(Python)三级考试试卷 真题及答案
java·python·算法