Leetcode 70 爬楼梯

题意理解

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。其中每次只能爬1阶或2阶。

问:爬到楼顶有几种走法?

如: n=1 爬一阶: 1

n=2 爬两阶: 1+1 要么从第1阶再爬一阶,要么从第0阶,一次性爬两阶

n=3 爬三界: 1+2 (1+1)+1 2+1

要么从第2阶再爬一阶即可,要么在第1阶一次性爬两阶即可

而爬到第1阶有一种方式,爬到第2阶有两种方式

故爬到第三阶有1+2=3种方式

则有递推公式:fi=fi-1+fi-2

解题思路

采用动态规划的方式求解此题,按照五个步骤来分析。

  1. 确定dp\[\]数组和下标的含义,其中dpi表示爬到第i阶有几种方式。

  2. 确定递归函数:dpi=dpi-1+dpi-2

  3. 初始化:dp1=1 dp2=2

  4. 确定遍历方式:总是前面的结果影响后续取值,所以遍历顺序总是从前到后

5.打印dp数组,用于debug

1.动态规划解题

java 复制代码
 public int climbStairs(int n) {
        //定义存储
        int[] dp=new int[n+1];
        //初始化
        dp[1]=1;
        if(n>1) dp[2]=2;
        //遍历
        for(int i=3;i<=n;i++){
            dp[i]=dp[i-1]+dp[i-2];
        }
        return dp[n];
    }

2.存储压缩

使用数值取代数组存储结果。空间复杂度O(n+1)------>O(3)

java 复制代码
public int climbStairs(int n) {
        //定义存储
        int sum=0,dp1=1,dp2=2;
        if(n==1) return dp1;
        if(n==2) return dp2;
        //初始化
        sum=dp1+dp2;
        //遍历
        for(int i=3;i<=n;i++){
            sum=dp1+dp2;
            dp1=dp2;
            dp2=sum;
        }
        return sum;
    }

3.分析

时间复杂度:O(n) 用于遍历n个状态值

空间复杂度

数组存储 O(n)

数值存储 O(1)

n表示输入的数值的大小。

相关推荐
少许极端3 分钟前
算法奇妙屋(五十二)-备战+复习2
java·算法
luj_17683 分钟前
硝酸核关联假说缺乏实验证据
c语言·开发语言·c++·经验分享·算法
fei_sun14 分钟前
【SystemVerilog验证】数据类型(待补充)
数据结构·systemverilog
青梅橘子皮29 分钟前
Linux---虚拟地址空间
linux·运维·算法
无忧.芙桃30 分钟前
数据结构之单链表
c语言·开发语言·数据结构
KaMeidebaby31 分钟前
卡梅德生物技术快报|酵母表达系统工程:裂殖酵母穿梭载体分子改造与载体构建技术总结
网络·人工智能·网络协议·tcp/ip·算法
HZ·湘怡34 分钟前
二叉树 1
数据结构·算法·二叉树·
雨落在了我的手上34 分钟前
Java数据结构(二):时间和空间复杂度
数据结构
悠仁さん43 分钟前
list 链式表基本功能模拟实现(双向有头指针循环链表)
c语言·数据结构·链表·list
吴可可1231 小时前
AutoCAD 2024搭配C#开发最佳实践
算法