代码随想录算法训练营第三十八天| 509. 斐波那契数,70. 爬楼梯 , 746. 使用最小花费爬楼梯

509. 递归经典入门,不难。需要注意在初始化dp数组的时候注意的是new int[n + 1], 不是n. 因为下标从0开始所以在遍历的时候要等==n再停止,最后返回dp的最后一个值就可以。

class Solution {
    public int fib(int n) {
        if (n <= 1) return n;             
        int[] dp = new int[n + 1];
       
        dp[0] = 0;
        dp[1] = 1;

        for(int i=2; i<=n; i++){
            dp[i] = dp[i-1] + dp[i-2];
        }
        return dp[n];
    }
}

70. 之前做过,跟上一题其实是差不多的。这里需要注意的是:

  1. n<=1的判断条件不能忘
  2. dp[0]其实考虑不考虑都没意义,dp[1]和dp[2]对了就行,dp[i]表示在i层台阶有几种跳法。
  3. 从i=3的时候开始遍历
class Solution {
    public int climbStairs(int n) {
        if(n<=1) return n;
        int[] dp = new int[n+1];
        dp[0] = 0;
        dp[1] = 1;
        dp[2] = 2;

        for(int i = 3; i<=n; i++){
            dp[i] = dp[i-1] + dp[i-2];
        }

        return dp[n];
    }
}

746. 上一题的演化。

  1. dp[i]的定义:到达第i台阶所花费的最少体力为dp[i]。
  2. 从下标为 0 或下标为 1 的台阶开始,因此支付费用为0

  3. dp[i] 的取值,可以是一步也可以是两步取最小值。!

    class Solution {
        public int minCostClimbingStairs(int[] cost) {
            int len = cost.length;
            int[] dp = new int[len + 1];
    
            // 从下标为 0 或下标为 1 的台阶开始,因此支付费用为0
            dp[0] = 0;
            dp[1] = 0;
    
            // 计算到达每一层台阶的最小费用
            for (int i = 2; i <= len; i++) {
                dp[i] = Math.min(dp[i - 1] + cost[i - 1], dp[i - 2] + cost[i - 2]);
            }
    
            return dp[len];
        }
    }

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-05-04 09:48:03       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-04 09:48:03       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-04 09:48:03       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-04 09:48:03       20 阅读

热门阅读

  1. 计算机网络 3.1网络的拓扑结构

    2024-05-04 09:48:03       13 阅读
  2. 计算机网络期末试题

    2024-05-04 09:48:03       12 阅读
  3. 【LeetCode】树的DFS(前序、中序、后序)精选10题

    2024-05-04 09:48:03       14 阅读
  4. 富格林:累积经验阻挠黑幕之手

    2024-05-04 09:48:03       12 阅读
  5. Django Admin报错“外键冲突”排查

    2024-05-04 09:48:03       11 阅读
  6. 你用过最好用的AI工具有哪些?

    2024-05-04 09:48:03       9 阅读
  7. 力扣经典150题第五十二题:简化路径

    2024-05-04 09:48:03       10 阅读
  8. NodeJs入门知识

    2024-05-04 09:48:03       11 阅读
  9. 平平科技工作室-Typescript 学习笔记

    2024-05-04 09:48:03       14 阅读
  10. Python基础学习之os模块

    2024-05-04 09:48:03       14 阅读
  11. 第二章 Python基础语法

    2024-05-04 09:48:03       11 阅读