算法训练(leetcode)二刷第二十八天 | 509. 斐波那契数、70. 爬楼梯、*746. 使用最小花费爬楼梯

刷题记录

  • [509. 斐波那契数](#509. 斐波那契数)
  • [70. 爬楼梯](#70. 爬楼梯)
  • [*746. 使用最小花费爬楼梯](#*746. 使用最小花费爬楼梯)

509. 斐波那契数

leetcode题目地址

时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( 1 ) O(1) O(1)

java 复制代码
// java
class Solution {
    public int fib(int n) {
        if(n<2) return n;
        int a = 0, b = 1, c = 0;
        for(int i=2; i<=n; i++){
            c = a + b;
            a = b;
            b = c;
        }
        return c;
    }
}

70. 爬楼梯

leetcode题目地址

依旧是斐波那契序列问题。

时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( 1 ) O(1) O(1)

java 复制代码
// java
class Solution {
    public int climbStairs(int n) {
        if(n<=3) return n;
        int a = 2, b = 3, c = 0;
        for(int i=4; i<=n; i++){
            c = a + b;
            a = b;
            b = c;
        }
        return c;
    }
}

*746. 使用最小花费爬楼梯

leetcode题目地址

动态规划

动态规划。每一步可以走一个台阶或两个台阶,因此,dp[i]记录到达第i个位置时所花费的开销,

  • 走一阶台阶到达dp[i]:dp[i] = dp[i-1] + cost[i-1]
  • 走两阶台阶到达dp[i]:dp[i] = dp[i-2] + cost[i-2]

因此,得到状态转移方程:
d p [ i ] = m i n ( d p [ i − 1 ] + c o s t [ i − 1 ] , d p [ i − 2 ] + c o s t [ i − 2 ] ) dp[i] = min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]) dp[i]=min(dp[i−1]+cost[i−1],dp[i−2]+cost[i−2])

时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( n ) O(n) O(n)

java 复制代码
// java
class Solution {
    public int minCostClimbingStairs(int[] cost) {
        int[] dp = new int[cost.length+1];
        for(int i=2; i<=cost.length; i++){
            dp[i] = Math.min(dp[i-1] + cost[i-1], dp[i-2] + cost[i-2]);
        }
        return dp[cost.length];
    }
}

优化空间复杂度

每一步的更新以来前两步的结果,因此只需要保留前两步即可。

时间复杂度: O ( n ) O(n) O(n)
空间复杂度: O ( 1 ) O(1) O(1)

java 复制代码
// java
class Solution {
    public int minCostClimbingStairs(int[] cost) {
        // int[] dp = new int[cost.length+1];
        int dp0 = 0, dp1 = 0;
        for(int i=2; i<=cost.length; i++){
            int dpi = Math.min(dp1 + cost[i-1], dp0 + cost[i-2]);
            dp0 = dp1;
            dp1 = dpi;
        }
        return dp1;
    }
}
相关推荐
Jeffrey_oWang2 分钟前
软间隔支持向量机支持向量的情况以及点的各种情况
算法·机器学习·支持向量机
我感觉。23 分钟前
【机器学习chp2】贝叶斯最优分类器、概率密度函数的参数估计、朴素贝叶斯分类器、高斯判别分析。万字超详细分析总结与思考
算法·机器学习·贝叶斯·朴素贝叶斯分类器·高斯判别分析
三小尛26 分钟前
归并排序(C语言)
c语言·数据结构·算法
Nonullpoint.1 小时前
对称加密与非对称加密:密码学的基石及 RSA 算法详解
java·计算机网络·算法·网络安全·密码学
AAA_bo11 小时前
每日一题3239.最少翻转次数使二进制矩阵回文;
算法
ahadee1 小时前
蓝桥杯每日真题 - 第15天
c语言·vscode·算法·蓝桥杯
戊子仲秋1 小时前
【LeetCode】每日一题 2024_11_16 最少翻转次数使二进制矩阵回文 II(矩阵,分类讨论)
leetcode·矩阵·分类
小吉在努力敲代码中1 小时前
c++实现B树(下)
开发语言·数据结构·c++·b树·算法
不爱学英文的码字机器2 小时前
[C++] 智能指针
开发语言·c++·算法
李元中2 小时前
24下软考高级【系统架构设计师】考试难度分析
网络·人工智能·经验分享·算法·系统架构·云计算