码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 算法训练(leetcode)第二十八天 | 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯


    刷题记录

    • 509. 斐波那契数
      • 递归
      • 循环
      • 动态规划
    • 70. 爬楼梯
    • 746. 使用最小花费爬楼梯

    509. 斐波那契数

    leetcode题目地址

    递归

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

    // c++
    class Solution {
    public:
        int fib(int n) {
            if(n<2) return n;
            return fib(n-1) + fib(n-2); 
        }
    };
    

    循环

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

    //c++
    class Solution {
    public:
        int fib(int n) {
            if(n<2) return n;
            int a=0, b=1;
            for(int i=2; i<=n; i++){
                swap(a, b);
                b += a;
            }
            return b;
        }
    };
    

    动态规划

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

    // c++
    class Solution {
    public:
        int fib(int n) {
            if(n<2) return n;
            vector<int> dp(n+1, 0);
            dp[1]=1;
            for(int i=2; i<=n; i++){
                dp[i] = dp[i-1] + dp[i-2]; 
            }
            return dp[n];
        }
    };
    

    70. 爬楼梯

    leetcode题目地址

    本质上还是斐波那契数列。用递归会在45处时间超限。

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

    // c++
    class Solution {
    public:
        int climbStairs(int n) {
            if(n<=2) return n;
            int a=1, b=2;
            for(int i=3; i<=n; i++){
                swap(a,b);
                b+=a;
            }
            return b;
            
        }
    };
    

    746. 使用最小花费爬楼梯

    leetcode题目地址

    动态规划。使用dp记录到达第i个楼梯所需要花费的费用。起始位置不需要支付费用,而起始位置可以是0和1,因此0、1位置的dp值为0.从2开始计算当前位置所需的最小花费。到达第i层的费用等于到达前一步的最小花费+前一步的花费。具体来说,若前一步是爬1个台阶到达第i层,则第i层的花费为cost[i-1]+dp[i-1];若前一步是爬2个台阶到达第i层,则第i层的花费为cost[i-2]+dp[i-2]。

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

    // c++
    class Solution {
    public:
        
        int minCostClimbingStairs(vector<int>& cost) {
            
            vector<int> dp(cost.size()+1, 0);
            for(int i=2; i<=cost.size(); i++){
                dp[i] = min(cost[i-1]+dp[i-1], cost[i-2]+dp[i-2]);
            }
            return dp[cost.size()];
        }
    };
    

    优化空间:上面的代码中起始每次都是只操作前面两个空间,因此只使用两个变量来计算既可。

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

    //c++
    class Solution {
    public:
        
        int minCostClimbingStairs(vector<int>& cost) {
            
            int a=0, b=0;
            for(int i=2; i<=cost.size(); i++){
                int mincost = min(cost[i-1]+b, cost[i-2]+a);
                a = b;
                b = mincost;
            }
            return b;
        }
    };
    
  • 相关阅读:
    基于行为树的高级游戏AI教程
    [ZJCTF 2019]NiZhuanSiWei - 伪协议+文件包含+反序列化
    大龄程序员三战考研变身考研战神
    折线图的代码
    verilog学习笔记(1)module实例化
    纸牌博弈问题
    设计模式从哪来、难学吗、什么时候学、能做什么?(设计模式与开发实践 P1)
    C++11、17、20的内存管理-指针、智能指针和内存池从基础到实战(中)
    VS2019配置Qt5.14.2以及在线配置Qt5.15.2
    python数据分析小案例:把招聘数据做可视化处理~
  • 原文地址:https://blog.csdn.net/weixin_43872997/article/details/140360267
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号