【LeetCode热题100】【动态规划】零钱兑换

题目链接:322. 零钱兑换 - 力扣(LeetCode)

要拿硬币凑钱,硬币无限多,就是完全背包问题,定义dp[i]是要凑的钱i的硬币数,对于当前硬币来说,如果选择了这个硬币,要么要凑的硬币数就变成dp[i-coin]

复制代码
class Solution {
public:
    int coinChange(vector<int> &coins, int amount) {
        vector<int> dp(amount + 1,INT_MAX / 2);
        dp[0] = 0;
        for (auto &coin: coins)
            for (int i = coin; i <= amount; ++i)
                dp[i] = min(dp[i], dp[i - coin] + 1);
        return dp[amount] == INT_MAX / 2 ? -1 : dp[amount];
    }
};
相关推荐
米粒18 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Fuxiao___9 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
Mr_Xuhhh9 小时前
LeetCode hot 100(C++版本)(上)
c++·leetcode·哈希算法
漫随流水9 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法
穿条秋裤到处跑11 小时前
每日一道leetcode(2026.03.31):字典序最小的生成字符串
算法·leetcode
CoovallyAIHub13 小时前
VisionClaw:智能眼镜 + Gemini + Agent,看一眼就能帮你搜、帮你发、帮你做
算法·架构·github
CoovallyAIHub13 小时前
低空安全刚需!西工大UAV-DETR反无人机小目标检测,参数减少40%,mAP50:95提升6.6个百分点
算法·架构·github
CoovallyAIHub13 小时前
IEEE Sensors | 湖南大学提出KGP-YOLO:先定位风电叶片再检测缺陷,三数据集mAP均超87%
算法
Yupureki13 小时前
《算法竞赛从入门到国奖》算法基础:动态规划-路径dp
数据结构·c++·算法·动态规划
副露のmagic14 小时前
数组章节 leetcode 思路&实现
算法·leetcode·职场和发展