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

【力扣】70. 爬楼梯 <动态规划>

【力扣】70. 爬楼梯

假设你正在爬楼梯。需要 n 阶你才能到达楼顶。每次你可以爬 1 或 2 个台阶。你有多少种不同的方法可以爬到楼顶呢?

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

1. 1+ 12. 2

示例 2:
输入:n = 3
输出:3
解释:有三种方法可以爬到楼顶。

1. 1+ 1+ 12. 1+ 23. 2+ 1

提示:
1 <= n <= 45

题解

  • 确定 dp 数组以及下标的含义
    dp[i] 的定义为:爬到第 i 层楼梯,有 dp[i] 种方法
  • 确定递推公式
    状态转移方程 dp[i] = dp[i - 1] + dp[i - 2];
  • dp 数组如何初始化
    dp[1] = 1,dp[2] = 2,不考虑 dp[0] 如何初始化
  • 确定遍历顺序
    从前向后遍历
  • 举例推导 dp 数组(打印 dp 数组)
    N 为5的时候,dp 数组应该是数列:1 2 3 5 8 (下标从1开始)
public int climbStairs(int n) {int[] dp = new int[n + 1];if (n <= 1) {return n;}dp[1] = 1;dp[2] = 2;for (int i = 3; i <= n; i++) {dp[i] = dp[i - 1] + dp[i - 2];}return dp[n];
}

变量代替数组:

 public int climbStairs(int n) {if(n <= 2) {return n;}int a = 1, b = 2, sum = 0;for(int i = 3; i <= n; i++){sum = a + b;  // f(i - 1) + f(i - 2)a = b;        // 记录f(i - 1),即下一轮的f(i - 2)b = sum;      // 记录f(i),即下一轮的f(i - 1)}return b;}
http://www.lryc.cn/news/136138.html

相关文章:

  • 数据结构(3)
  • 深入浅出Pytorch函数——torch.nn.init.xavier_uniform_
  • 优橙内推安徽专场——5G网络优化(中高级)工程师
  • 2023年计算机设计大赛国三 数据可视化 (源码可分享)
  • 工业生产全面感知!工业感知云来了
  • Lnton羚通关于Optimization在【PyTorch】中的基础知识
  • 冒泡排序算法
  • 无人机航管应答机 ping200XR
  • oracle归档日志满了导致启动不起来解决
  • 高等数学:线性代数-第二章
  • 星戈瑞分析FITC-PEG-Alkyne的荧光特性和光谱特性
  • VB.NET调用VB6 Activex EXE实现PowerBasic和FreeBasic的标准DLL调用
  • 深入了解Unity的Physics类:一份详细的技术指南(七)(下篇)
  • C++入门:引用是什么
  • 2023年人工智能与自动化控制国际学术会议(AIAC 2023)
  • 分布式核心知识以及常见微服务框架
  • Unity记录4.1-存储-根据关键字加载Tile
  • 数据结构—树表的查找
  • 微信小程序测试策略和注意事项?
  • VUE3封装EL-ELEMENT-PLUS input组件
  • RISC-V公测平台发布 · 在SG2042上配置Jupiter+Octave科学计算环境
  • 初识Sentinel
  • 【官方中文文档】Mybatis-Spring #注入映射器
  • UG\NX 二次开发 相切面、相邻面的选择控件
  • Quartz任务调度框架介绍和使用
  • drools8尝试
  • 【机器学习】python基础实现线性回归
  • vue table合并行 动态列名
  • Spring Cloud Alibaba-Nacos Discovery--服务治理
  • 【C++】unordered_map和unordered_set的使用 及 OJ练习