备战秋招60天算法挑战,Day28

devtools/2024/10/23 15:22:44/

题目链接: https://leetcode.cn/problems/climbing-stairs/

视频题解: https://www.bilibili.com/video/BV1h1421t7W3/

LeetCode 70.爬楼梯

题目描述

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

举个例子:

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

视频题解

爬楼梯

思路来源

思路来源

知识回顾

动态规划是一种通过将原问题分解为子问题来求解复杂问题的算法思想。它通常用于求解最优化问题,例如最长公共子序列、背包问题等。动态规划的核心思想是将原问题分解为若干个子问题,通过求解子问题的最优解推导出原问题的最优解。可以通过两点来判断一个问题能不能通过动态规划来解,一是该问题是否存在递归结构,二是对应的子问题能否记忆化。动态规划可以通过带备忘录的自上而下的递归自下而上的迭代来分别实现。由于递归需要用到栈来实现,一些语言对递归的深度是有限制的,所以自下而上的迭代是动态规划的最佳实现方式

思路解析

假设只有4个台阶,0阶代表地面。

整个爬楼梯的过程对应的决策树可以表示成下图:

每个节点的值表示剩余的台阶数,从根节点到叶子结点组成的路径代表一种爬楼梯的方法。

整个决策树存在递归结构,还存在重复子问题两个节点2三个节点1,这些子问题计算一次后可以直接保存下来,避免多次重复计算。这就满足了使用动态规划的条件:存在递归结构子问题可以记忆化。所以本题可以用动态规划来解,动态规划的两个核心点是推导状态转移公式边界处理

定义dp[i]i个台阶对应的爬楼梯的方法个数dp[i]的准确定义是推导状态转移公式的关键。

因为每次只能爬12个台阶,从上面的图可以看出4个台阶的爬楼梯方法可以拆解成32个台阶爬楼梯方法之和。说白了就是节点4到叶子节点0的所有路径等于节点3节点2到叶子节点路径的总和。
d p [ 4 ] = d p [ 3 ] + d p [ 2 ] dp[4] = dp[3] + dp[2] dp[4]=dp[3]+dp[2]

4个台阶进一步扩展到n个台阶,我们得到下面的状态转移公式
d p [ i ] = d p [ i − 1 ] + d p [ i − 2 ] , 1 < i < = n dp[i] = dp[i-1] + dp[i-2], 1 < i <= n dp[i]=dp[i1]+dp[i2],1<i<=n

接下来进行边界处理,根据上面的公式可知 d p [ 2 ] = d p [ 1 ] + d p [ 0 ] dp[2] = dp[1] + dp[0] dp[2]=dp[1]+dp[0],很显然dp[1] = 1dp[2] = 2,上面也说到0阶代表地面,为了写代码方便这里我们定义dp[0] = 1

C++代码

class Solution {
public:int climbStairs(int n) {//因为有n阶台阶,台阶从0开始计算,所以定义n+1个元素vector<int> dp(n+1, 0);//定义边界dp[0]=1dp[0] = 1;dp[1] = 1;for (int i = 2; i <= n; ++i) {//状态转移公式dp[i] = dp[i-1] + dp[i-2];}return dp[n];}
};

java_75">java代码

java">class Solution {public int climbStairs(int n) {// 因为有n阶台阶,台阶从0开始计算,所以定义n+1个元素int[] dp = new int[n + 1];// 定义边界dp[0]=1dp[0] = 1;dp[1] = 1;for (int i = 2; i <= n; ++i) {// 状态转移公式dp[i] = dp[i-1] + dp[i-2];}return dp[n];}
}

python_94">python代码

python">class Solution:def climbStairs(self, n: int) -> int:# 因为有n阶台阶,台阶从0开始计算,所以定义n+1个元素dp = [0] * (n + 1)# 定义边界dp[0]=1dp[0] = 1dp[1] = 1for i in range(2, n + 1):# 状态转移公式dp[i] = dp[i-1] + dp[i-2]return dp[n]

上面的代码实现使用了一个长为n+1dp数组,我们观察状态转移公式的规律,其实并不需要保存每个台阶数为i的爬楼梯方法,可以通过两个整型变量来优化上面的实现。

c++代码

class Solution {
public:int climbStairs(int n) {int pre = 1;int next = 1;for (int i = 2; i <= n; ++i) {int temp = next;next = pre + next;pre = temp;}return next;}
};

java_132">java代码

java">class Solution {public int climbStairs(int n) {int pre = 1;int next = 1;for (int i = 2; i <= n; ++i) {int temp = next;next = pre + next;pre = temp;}return next;}
}

python_149">python代码

python">class Solution:def climbStairs(self, n: int) -> int:pre = 1next = 1for i in range(2, n + 1):temp = nextnext = pre + nextpre = tempreturn next

复杂度分析

时间复杂度: 两种实现方式的时间复杂度都是O(n)n为台阶的个数。

空间复杂度: 第一种实现方式的空间复杂度为O(n)n为台阶的个数。第二种实现方式的空间复杂度为O(1)


http://www.ppmy.cn/devtools/103621.html

相关文章

财富趋势金融大模型已通过备案

财富趋势金融大模型已通过备案 8月28日晚&#xff0c;国内领先的证券软件与信息服务提供商——财富趋势&#xff0c;公布了其2024年上半年财务报告&#xff1a; 今年上半年&#xff0c;财富趋势营收1.48亿元&#xff0c;同比增长0.14%&#xff1b;实现归母净利润为1亿元&#x…

[Meachines] [Medium] Bastard Drupal 7 Module Services-RCE+MS15-051权限提升

信息收集 IP AddressOpening Ports10.10.10.9TCP:80,135,49154 $ nmap -p- 10.10.10.9 --min-rate 1000 -sC -sV PORT STATE SERVICE VERSION 80/tcp open http Microsoft IIS httpd 7.5 | http-methods: |_ Potentially risky methods: TRACE | http-robots.…

Linux下C编程使用动态链接库

为了方便程序功能的后期升级扩展&#xff0c;在程序设计时经常会用到动态库&#xff0c;这样子程序只有到运行阶段才会去加载动态库并且使用库中的函数&#xff0c;那么我们往往只需要更新DLL&#xff08;Windows系统&#xff09;或SO&#xff08;Linux系统&#xff09;文件即可…

Docker php文件本地包含--pearcmd.php利用

目录 前言 环境搭建 pearcmd.php巧妙利用 渗透 前言 docker包含日志文件&#xff0c;基本不可能&#xff0c;就以我自身的一个项目来说&#xff0c;在尝试包含日志文件时发现&#xff0c;客户将他的日志文件从定向到了设备文件&#xff0c;而php没有包含设备文件的权限 然…

【DSP+FPGA】基于Virtex-7 FPGA + C6678 DSP的高性能实时信号处理平台

DSP FPGA 协同处理架构板载 1 个TMS320C6678 多核DSP处理节点板载 1 片 XC7VX690T FPGA处理节点板载 1 个FMC 接口板载4路SFP光纤接口FPGA 与 DSP 之间采用高速Rapid IO互联 基于Virtex-7 FPGA的高性能实时信号处理平台&#xff0c;该平台采用1片TI的KeyStone系列多核DSP TMS3…

在Spring Boot项目中使用MySQL数据库

一、引言 MySQL 是一个广泛使用的开源关系型数据库&#xff0c;而 Spring Boot 则是一个流行的 Java 框架&#xff0c;提供了快速构建生产级别的独立 Spring 应用的能力。将 MySQL 与 Spring Boot 集成&#xff0c;可以轻松地管理应用的数据存储。本文将介绍如何在 Spring Boo…

SLAM ORB-SLAM2(29)PnP估计姿态

SLAM ORB-SLAM2&#xff08;29&#xff09;PnP估计姿态 1. PnP问题2. EPnP算法2.1. 计算4对控制点的世界坐标2.2. 计算齐次质心坐标2.3. 计算4对控制点的相机坐标2.3.1. 构造M矩阵2.3.2. 计算 M T M M^TM MTM的0特征值对应的特征向量2.3.3. 计算零空间的秩2.3.4. 计算线性组合的…

鸿蒙HarmonyOS开发:如何使用第三方库,加速应用开发

文章目录 一、如何安装 ohpm-cli二、如何安装三方库1、在 oh-package.json5 文件中声明三方库&#xff0c;以 ohos/crypto-js 为例&#xff1a;2、安装指定名称 pacakge_name 的三方库&#xff0c;执行以下命令&#xff0c;将自动在当前目录下的 oh-package.json5 文件中自动添…