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

爬楼梯(力扣LeetCode)动态规划

爬楼梯

题目描述

假设你正在爬楼梯。需要 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

动规五部曲:

定义⼀个⼀维数组来记录不同楼层的状态

  1. 确定dp数组以及下标的含义
    dp[i]: 爬到第i层楼梯,有dp[i]种⽅法
  2. 确定递推公式
    在这里插入图片描述
    从第三层开始,第n层需要的步伐等于第n-1层需要的步伐加上第n-2层需要的步伐
    例如:第三层=(第一层+2)+ (第二层+1)
    第四层=(第二层+2) + (第三层+1)
  3. dp数组如何初始化
    不考虑dp[0]如何初始化,只初始化dp[1] = 1,dp[2] = 2,然后从i = 3开始递推,这样才符合
    dp[i]的定义。
  4. 确定遍历顺序
    从递推公式dp[i] = dp[i - 1] + dp[i - 2];中可以看出,遍历顺序⼀定是从前向后遍历的
  5. 举例推导dp数组
    举例当n为5的时候,dp table(dp数组)应该是这样的
    在这里插入图片描述如果代码出问题了,就把dp table 打印出来,看看究竟是不是和⾃⼰推导的⼀样。
    此时⼤家应该发现了,这不就是斐波那契数列么!
    唯⼀的区别是,没有讨论dp[0]应该是什么,因为dp[0]在本题没有意义!

代码

力扣提交代码

class Solution {
public:
	int climbStairs(int n) {
		if (n <= 1) return n; // 因为下⾯直接对dp[2]操作了,防⽌空指针
		vector<int> dp(n + 1);
		dp[1] = 1;
		dp[2] = 2;
		for (int i = 3; i <= n; i++) { // 注意i是从3开始的
			dp[i] = dp[i - 1] + dp[i - 2];
		}
		return dp[n];
	}
};

总代码

#include<bits/stdc++.h>
using namespace std;

int climbStairs(int n) 
{
    if(n<=2)
    	return n;
    int dp[50]={0};
    dp[1]=1;
    dp[2]=2;
    int i;
    for(i=3;i<=n;i++)
    	dp[i]=dp[i-1]+dp[i-2];
    return dp[n];
}

int main()
{
	int n;
	scanf("n = %d",&n);
	cout<<climbStairs(n);
	return 0;
}

http://www.kler.cn/a/148612.html

相关文章:

  • Java static静态变量 C语言文件读写
  • 【数据结构】线性表——链表
  • 关于分治法左右区间单调遍历应该如何设计
  • 如何平滑切换Containerd数据目录
  • Golang | Leetcode Golang题解之第546题移除盒子
  • FPGA学习笔记#5 Vitis HLS For循环的优化(1)
  • Win7 SP1 x64 Google Chrome 字体模糊
  • android系统新特性——用户界面以及系统界面改进
  • 记录一次因内存不足而导致hiveserver2和namenode进程宕机的排查
  • Vue项目实战之一----实现分类弹框效果
  • 【华为OD题库-037】跳房子2-java
  • Vue组件实战:列表组件开发
  • AIGC系列之:CLIP和OpenCLIP
  • Kubernetes异常排查方式
  • 【Linux】coredump 文件的例子分析
  • 4:kotlin 方法(Functions)
  • 看懂YOLOv7混淆矩阵的含义,正确计算召回率、精确率、误检率、漏检率
  • 面试:线上问题处理
  • sqli-labs(3)
  • 达梦数据库ddl锁等待时间太短?解决方法
  • 万字详解,和你用RAG+LangChain实现chatpdf
  • 进程、线程以及进程与线程的区别
  • 内测分发平台是否支持应用的微服务化部署
  • 力扣二叉树--总结篇(1)
  • 乐观锁和悲观锁
  • 强化学习中的深度Q网络