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];
}
相关推荐
夏乌_Wx1 天前
练题100天——DAY23:存在重复元素Ⅰ Ⅱ+两数之和
数据结构·算法·leetcode
ada7_1 天前
LeetCode(python)108.将有序数组转换为二叉搜索树
数据结构·python·算法·leetcode
独自破碎E1 天前
加油站环路问题
java·开发语言·算法·leetcode
Swift社区1 天前
LeetCode 445 - 两数相加 II
算法·leetcode·职场和发展
墨染点香1 天前
LeetCode 刷题【187. 重复的DNA序列】
算法·leetcode·职场和发展
2401_841495641 天前
【LeetCode刷题】最大子数组和
数据结构·python·算法·leetcode·动态规划·最大值·最大子数组和
鹿角片ljp1 天前
力扣101.判断对称二叉树-推荐掌握递归
算法·leetcode·职场和发展
2401_841495641 天前
【LeetCode刷题】最小覆盖字串
数据结构·python·算法·leetcode·字符串·双指针·滑动窗口算法
qk学算法1 天前
力扣算法——二分最大值最小值
数据结构·算法·leetcode