当前位置: 首页 > news >正文

Leetcode 70.爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。

每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

示例 1:

输入:n = 2
输出:2
解释:有两种方法可以爬到楼顶。
1. 1 阶 + 1 阶
2. 2 阶

示例 2:

输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。
1. 1 阶 + 1 阶 + 1 阶
2. 1 阶 + 2 阶
3. 2 阶 + 1 阶

提示:

  • 1 <= n <= 45

方法一: 记忆化搜索

class Solution {public int climbStairs(int n) {int[] store = new int[n + 1];return dfs(n, store);}private int dfs(int i, int[] store){if(i <= 1){return 1;}if(store[i] != 0){return store[i];}return store[i] = dfs(i - 1, store) + dfs(i - 2, store);}
}

方法二:递推

class Solution {public int climbStairs(int n) {int[] f = new int[n + 1];f[0] = f[1] = 1;//f[2];for(int i = 2; i <= n; i++){f[i] = f[i - 1] + f[i - 2];}return f[n];}
}

方法三:空间优化

class Solution {public int climbStairs(int n) {int f0 = 1;int f1 = 1;for(int i = 2; i <= n; i++){int newF = f0 + f1;f0 = f1;f1 = newF;}return f1;}
}

http://www.lryc.cn/news/425805.html

相关文章:

  • Spring Boot集成钉钉群通知机器人
  • SpringAOP 面向切面编程
  • 灵办AI助手Chrome插件全面评测:PC Web端的智能办公利器
  • Rancher 使用 Minio 备份 Longhorn 数据卷
  • useRequest
  • python动画:manim实现多面体的创建
  • 数值计算引擎:搭建远程容器开发环境
  • 二叉搜索树(Binary Search Tree)
  • Yii2框架的初始化及执行流程
  • 2024.1-2024.2pycharm无法打开terminal命令行
  • 50ETF期权移仓是什么?50ETF期权移仓要注意什么?
  • 软件工程概述(上)
  • 阿里云ubuntu系统安装mysql8.0
  • 自己搭建远程桌面服务器-RustDesk 极简版
  • 数字资产是什么?怎么产生?怎么增长?
  • Centos7升级gitlab(17)
  • Zookeeper详解以及常见的高可用关联组件
  • Docker Containerd初体验
  • 开始使用 AWS SAM CLI
  • RK3588 RTL8125BG调试
  • Python自省(机制与函数)
  • 【JavaEE】JVM 内存区域划分,以及 Java 垃圾回收机制引用计数器,可达性分析等
  • Web开发:C# MVC + Session机制实现授权免登录demo
  • 【Qt】QWidget的font属性
  • 每天一个数据分析题(四百八十五)- 统计推断
  • 基于STM32的农业病虫害检测检测系统:OpenCV、MQTT、Flask框架、MySQL(代码示例)
  • 算法日记day 39(动归之打家劫舍)
  • Vue 生命周期详解含demo、面试常问问题案例
  • 表单自定义规则的校验
  • JVM 有哪些垃圾回收算法(回收机制)?