yq—2024/5/29—零钱兑换


代码实现:

cpp 复制代码
#define min(a, b) ((a) > (b) ? (b) : (a))

int coinChange(int *coins, int coinsSize, int amount) {
    int dp[amount + 1];
    // 初始化
    for (int i = 0; i < amount + 1; i++) {
        dp[i] = INT32_MAX;
    }
    dp[0] = 0;
    // 01背包 -----先遍历物品,再遍历背包
    // for (int i = 0; i < coinsSize; i++) { // 遍历物品
    //     for (int j = coins[i]; j <= amount; j++) { // 遍历背包
    //         if (dp[j - coins[i]] != INT32_MAX) { // 如果dp[j - coins[i]]是初始值则跳过
    //             dp[j] = min(dp[j - coins[i]] + 1, dp[j]);
    //         }
    //     }
    // }

    // 01背包 -----先遍历背包,再遍历物品
    for (int j = 0; j <= amount; j++) { // 遍历背包
        for (int i = 0; i < coinsSize; i++) { // 遍历物品
            if (j >= coins[i] && dp[j - coins[i]] != INT32_MAX) { // 如果dp[j - coins[i]]是初始值则跳过
                dp[j] = min(dp[j - coins[i]] + 1, dp[j]);
            }
        }
    }
    if (dp[amount] == INT32_MAX) {
        return -1;
    }
    return dp[amount];
}
相关推荐
踩坑记录7 小时前
leetcode hot100 11.盛最多水的容器 medium 双指针
算法·leetcode·职场和发展
圣保罗的大教堂7 小时前
leetcode 865. 具有所有最深节点的最小子树 中等
leetcode
X在敲AI代码8 小时前
LeetCode 基础刷题D2
算法·leetcode·职场和发展
源代码•宸8 小时前
Leetcode—1929. 数组串联&&Q1. 数组串联【简单】
经验分享·后端·算法·leetcode·go
weixin_461769408 小时前
15. 三数之和
c++·算法·leetcode·三数之和
千金裘换酒9 小时前
LeetCode 链表两数相加
算法·leetcode·链表
独自破碎E10 小时前
二分查找-I
leetcode
千金裘换酒10 小时前
LeetCode 删除链表的倒数第N个结点
算法·leetcode
老鼠只爱大米11 小时前
LeetCode算法题详解 42:接雨水
leetcode·动态规划·双指针·单调栈·接雨水·雨水收集
AlenTech11 小时前
739. 每日温度 - 力扣(LeetCode)
算法·leetcode·职场和发展