算法训练(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题目地址

动态规划

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

  • 走一阶台阶到达dpi:dpi = dpi-1 + costi-1
  • 走两阶台阶到达dpi:dpi = dpi-2 + costi-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 ) dpi = min(dpi-1 + costi-1, dpi-2 + costi-2) dpi=min(dpi−1+costi−1,dpi−2+costi−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;
    }
}
相关推荐
8Qi83 小时前
LeetCode 75:颜色分类(荷兰国旗问题)—— Java 题解 ✅
java·算法·leetcode·指针·排序
888CC++4 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
(●—●)橘子……6 小时前
力扣第503场周赛练习理解
python·学习·算法·leetcode·职场和发展·周赛
明志数科7 小时前
4D时序标注技术详解:让机器人理解连续动作的数据基础
java·算法·机器人
KaMeidebaby8 小时前
卡梅德生物技术快报|原核表达系统工艺优化:包涵体重折叠 + 分子筛纯化实现功能 RBD 高效制备,附全参数配置
前端·人工智能·算法·数据挖掘·数据分析
无限码力8 小时前
携程0510笔试真题【单数组交换】
算法·携程笔试·携程笔试真题·携程0510笔试真题
BlockWay9 小时前
WEEX Labs 周度观察:微软-OpenAI 合作调整与AI 多云趋势
大数据·人工智能·算法·安全·microsoft
风筝在晴天搁浅9 小时前
快手 CodeTop LeetCode 224.基本计算器
数据结构·算法·leetcode
Smoothcloud润云9 小时前
5大功能精修,重构AI算力使用体验!
java·人工智能·windows·算法·重构·编辑器·sublime text