【动态规划】Leetcode 746. 使用最小花费爬楼梯

【动态规划】Leetcode 746. 使用最小花费爬楼梯

---------------🎈🎈题目链接🎈🎈-------------------

解法

😒: 我的代码实现============>

动规五部曲

✒️确定dp数组以及下标的含义

dp[i] 表示跳跃到第 i 层,需要的最少花费总和

✒️确定递推公式

可以有两个途径得到dp[i],一个是dp[i-1] 一个是dp[i-2]。
dp[i-1] :表示跳到 i -1 层需要的花费
dp[i-2] :表示跳到 i -2 层需要的花费
从dp[i-1] 跳到 dp[i] 层需要的花费:dp[i-1] + cost[i-1]
从dp[i-2] 跳到 dp[i] 层需要的花费:dp[i-2] + cost[i-2]

那么究竟是选从dp[i - 1]跳还是从dp[i - 2]跳呢?——选小的
因此: dp[i] = Min( dp[i-1] + cost[i-1] , dp[i-2] + cost[i-2] )

✒️dp数组初始化

在第0层,和第1层的时候不花费。
如果要跳走,那就需要花费
所以初始化dp[0] = 0 , dp[1] = 1

✒️确定遍历顺序

从前到后

✒️举例推导dp数组

时间复杂度O(N)
空间复杂度O(N)

📘代码

class Solution {
    public int minCostClimbingStairs(int[] cost) {
        // 动态规划
        // dp数组:dp[i] 到达第i台阶所花费的最少费用为dp[i]
        int[] dp = new int[cost.length+1];
        // 到达第0层和第1层不需要花费,所以初始化为:
        dp[0] = 0;
        dp[1] = 0;
        for(int i = 2; i < cost.length+1; i++){ // 顺序遍历 从2开始到到达楼梯顶部(cost.length+1)
            dp[i] = Math.min( (dp[i-1] + cost[i-1]), (dp[i-2] + cost[i-2]) );
        }
        return dp[cost.length];
    }   

相关推荐

  1. 动态规划 Leetcode 746 使用花费楼梯

    2024-03-24 14:42:04       16 阅读
  2. leetcode746.使用花费楼梯动态规划

    2024-03-24 14:42:04       9 阅读
  3. LeetCode 746. 使用花费楼梯

    2024-03-24 14:42:04       46 阅读
  4. LeetCode 746. 使用花费楼梯

    2024-03-24 14:42:04       20 阅读
  5. LeetCode 746. 使用花费楼梯

    2024-03-24 14:42:04       13 阅读
  6. LeetCode 746.使用花费楼梯

    2024-03-24 14:42:04       4 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-24 14:42:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-24 14:42:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-24 14:42:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-24 14:42:04       18 阅读

热门阅读

  1. 【力扣】268.丢失的数字

    2024-03-24 14:42:04       18 阅读
  2. 防火墙有哪些特点?

    2024-03-24 14:42:04       15 阅读
  3. Web框架开发-Django-数据库表的单表查询

    2024-03-24 14:42:04       19 阅读
  4. new world of dream

    2024-03-24 14:42:04       17 阅读
  5. flask项目部署

    2024-03-24 14:42:04       17 阅读
  6. MATLAB下载+安装教程

    2024-03-24 14:42:04       20 阅读
  7. Tomcat

    Tomcat

    2024-03-24 14:42:04      18 阅读
  8. 关于Mysql表中使用‘utf8mb4_unicode_ci’字符集问题

    2024-03-24 14:42:04       19 阅读
  9. 音频变压器电感的工艺结构原理及选型参数总结

    2024-03-24 14:42:04       17 阅读
  10. C++知识点总结(26):队列

    2024-03-24 14:42:04       15 阅读