【leetcode刷题日记】lc.322-零钱兑换

目录

1.题目

2.代码


1.题目

给你一个整数数组 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

提示:

  • 1 <= coins.length <= 12
  • 1 <= coins[i] <= 231 - 1
  • 0 <= amount <= 104

2.代码

cpp 复制代码
class Solution {
public:
    bool cmp(int a,int b)
    {
        return a>b;
    }
    int coinChange(vector<int>& coins, int amount) {
        int n=coins.size();
        int dp[10001];
        dp[0]=0;
        for(int i=1;i<=amount;i++)
        {
            dp[i] = amount+1;
            for(int j=0;j<n;j++)
            {
                if(i-coins[j]>=0)
                {
                    dp[i]=min(dp[i],dp[i-coins[j]]+1);
                }
            }
        }
        if(dp[amount]==amount+1)
        {
            return -1;
        }
        return dp[amount];
    }
};
相关推荐
朱剑君1 小时前
第四天——贪心算法——种花
算法·贪心算法
TextIn智能文档云平台1 小时前
PDF文档解析新突破:图表识别、公式还原、手写字体处理,让AI真正读懂复杂文档!
图像处理·人工智能·算法·自然语言处理·pdf·ocr
Panesle2 小时前
HunyuanCustom:文生视频框架论文速读
人工智能·算法·音视频·文生视频
hie988942 小时前
matlab稳定求解高精度二维对流扩散方程
算法·机器学习·matlab
买了一束花2 小时前
MATLAB导出和导入Excel文件表格数据并处理
人工智能·算法·matlab
纪元A梦2 小时前
贪心算法应用:顶点覆盖问题详解
java·算法·贪心算法
爱补鱼的猫猫4 小时前
22、近端策略优化算法(PPO)论文笔记
论文阅读·算法
开心星人4 小时前
【论文阅读】Reconstructive Neuron Pruning for Backdoor Defense
论文阅读·算法·剪枝
_Itachi__5 小时前
LeetCode 热题 100 543. 二叉树的直径
java·算法·leetcode
是代码侠呀5 小时前
飞蛾扑火算法matlab实现
开发语言·算法·matlab·github·github star·github 加星