数据结构刷题(三十三):完全背包最小值情况。322. 零钱兑换、279. 完全平方数

题目一:

322. 零钱兑换https://leetcode.cn/problems/coin-change/

思路:完全背包问题,求解最小组合数。dp[j]:凑足总额为j所需钱币的最少个数为dp[j]。同时需要确保凑足总金额为0所需钱币的个数一定是0,那么dp[0] = 0;

注意:本题代码使用先遍历物品(也就是硬币),再遍历背包(amount)

代码:

java 复制代码
class Solution {
    public int coinChange(int[] coins, int amount) {
        int n = coins.length;
        int[] dp = new int[amount + 1];
        Arrays.fill(dp, Integer.MAX_VALUE);
        dp[0] = 0;
        // 当j<coins[i]时:装不下,继承上一个dp[j]的值
        // 当j>=coins[i]时:可以装得下,可以选择装或者不装中价值小的(物品数小的)进行转移
           即:dp[j]=min(dp[j],dp[j-coins[i]+1])
        for (int i = 0; i < n; i++){
            for (int j = coins[i]; j <= amount; j++){
                 if (dp[j - coins[i]] != Integer.MAX_VALUE)
                    // 比较之前的dp[j]与新的也就是去掉当前coins[i]的dp[j-coins[i]]比较
                    // +1加的是当前的coins[i]
                     dp[j] = Math.min(dp[j], dp[j - coins[i]] + 1);
            }
        }
        // 如果没有命中则直接返回-1
        return dp[amount] == Integer.MAX_VALUE ? -1 : dp[amount];
    }
}

题目二:

279. 完全平方数https://leetcode.cn/problems/perfect-squares/

本题翻译:完全平方数就是物品(可以无限件使用),凑个正整数n就是背包,问凑满这个背包最少有多少物品?

思路:完全背包问题,思路类似零钱兑换。还是先遍历物品(数字),再遍历背包(正整数n)。

代码:

java 复制代码
class Solution {
    public int numSquares(int n) {
        int[] dp = new int[n + 1];
        // 全部初始化为最大值
        Arrays.fill(dp, Integer.MAX_VALUE);
        dp[0] = 0;
        // 遍历所有物品,必须保证≤,
        for (int i = 1; i * i <= n; i++) {
            // 后遍历背包n
            for (int j = i * i; j <= n; j++){
                dp[j] = Math.min(dp[j], dp[j - i * i] + 1);
            }
        }
        return dp[n];
    }
}
相关推荐
朝朝又沐沐3 小时前
算法竞赛阶段二-数据结构(36)数据结构双向链表模拟实现
开发语言·数据结构·c++·算法·链表
艾莉丝努力练剑4 小时前
【数据结构与算法】数据结构初阶:详解排序(二)——交换排序中的快速排序
c语言·开发语言·数据结构·学习·算法·链表·排序算法
科大饭桶4 小时前
数据结构自学Day13 -- 快速排序--“前后指针法”
数据结构·算法·leetcode·排序算法·c
设计师小聂!7 小时前
力扣热题100----------53最大子数组和
java·数据结构·算法·leetcode
YouQian7727 小时前
问题 C: 字符串匹配
c语言·数据结构·算法
yanxing.D7 小时前
408——数据结构(第二章 线性表)
数据结构·算法
艾莉丝努力练剑8 小时前
【LeetCode&数据结构】二叉树的应用(二)——二叉树的前序遍历问题、二叉树的中序遍历问题、二叉树的后序遍历问题详解
c语言·开发语言·数据结构·学习·算法·leetcode·链表
waveee1239 小时前
学习嵌入式的第三十三天-数据结构-(2025.7.25)服务器/多客户端模型
服务器·数据结构·学习
花开富贵ii10 小时前
代码随想录算法训练营二十八天|动态规划part01
java·数据结构·算法·leetcode·动态规划
Swiler11 小时前
数据结构第1问:什么是数据结构?
数据结构·算法