70. 爬楼梯 (进阶),322. 零钱兑换,279.完全平方数

代码随想录训练营第45天|70. 爬楼梯 (进阶,322. 零钱兑换,279.完全平方数

70.爬楼梯

文章

代码随想录|0070.爬楼梯完全背包版本

思路

将楼梯长度视为背包容量,将一步的跨度视为物品价值,则可以转化为完全背包问题

代码

java 复制代码
class Solution {
    public int climbStairs(int n) {
        int i, j;
        int[] dp = new int[n + 1];
        dp[0] = 1;
        for (j = 0; j < n + 1; ++j) {
            for (i = 0; i < 2; ++i) {
                if (j >= i + 1) {
                    dp[j] += dp[j - i - 1];
                }
            }
        }
        return dp[n];
    }
}

322.零钱兑换

文章

代码随想录|0322.零钱兑换

思路

dp数组初始化全为正无穷

dp0单独设为0

外层遍历物品,内层遍历背包容积
d p j = M i n ( d p j , d p j − c o i n s \[ i ] + 1 ) dpj=Min(dpj, dpj-coins\[i]+1) dpj=Min(dpj,dpj−coins\[i]+1)

代码

java 复制代码
public class Solution {
    public int coinChange(int[] coins, int amount) {
        int max = amount + 1;
        int[] dp = new int[amount + 1];
        Arrays.fill(dp, max);
        dp[0] = 0;
        for (int i = 1; i <= amount; i++) {
            for (int j = 0; j < coins.length; j++) {
                if (coins[j] <= i) {
                    dp[i] = Math.min(dp[i], dp[i - coins[j]] + 1);
                }
            }
        }
        return dp[amount] > amount ? -1 : dp[amount];
    }
}

279.完全平方数

文章

代码随想录|0279.完全平方数

思路

n为背包容量,i^2为物品价值,单个物品最大价值为sqrt(n)
d p j = M i n ( d p j , d p j − i 2 + 1 ) dpj=Min(dpj,dpj-i\^2+1) dpj=Min(dpj,dpj−i2+1)

代码

java 复制代码
class Solution {
    public int numSquares(int n) {
        int i, j;
        int[] dp = new int[n + 1];
        Arrays.fill(dp, n);
        dp[0] = 0;
        int upper = (int) Math.sqrt(n);
        for (i = 1; i <= upper; ++i) {
            for (j = 1; j < n + 1; ++j) {
                if (j >= i * i) {
                    dp[j] = Math.min(dp[j], dp[j - i * i] + 1);
                }
            }
        }
        return dp[n];
    }
}

总结

二刷,还是会出错

牢牢记住,求组合数外层物品内层背包

相关推荐
San813_LDD1 小时前
[C语言]《Dev-C++ 报错解决手册(Day0607 精华版)》
java·前端·javascript
Anastasiozzzz2 小时前
从有限状态机到智能体图:传统 FSM 与 Agent Graph的演进
java·人工智能·python·ai
wang09078 小时前
自己动手写一个spring之IOC_2
java·后端·spring
来杯@Java8 小时前
学生选课管理系统(基于springboot+vue前后端分离的项目)计算机毕业设计java
java·spring boot·spring·vue·毕业设计·maven·mybatis
不知名的老吴9 小时前
线程的生命周期之线程“插队“
java·开发语言·python
ANnianStriver9 小时前
PetLumina-02-后端开发与前后端联调
java·ai·sa-token
杨了个杨898210 小时前
Keepalived + Nginx + HAProxy 高可用架构部署实战案例
java·nginx·架构
8Qi811 小时前
LeetCode 516:最长回文子序列
算法·leetcode·职场和发展·动态规划
马士兵教育12 小时前
Java还有前景吗?Java+AI大模型学习路线及项目?
java·人工智能·python·学习·机器学习