前端算法 | LeetCode第 70 题爬楼梯问题

目录

流程分析

归纳法分析

为什么是斐波那契数列?

推导过程:

解法1:循环累加计算

解法2:递归计算

解法3:利用数组特性

解法4:利用 JavaScript ES6 新特性

拓展知识:每次可以走 1 步、2 步、3 步

拓展知识:斐波那契数列


本题为 LeetCode第70题爬楼梯,题目如下:

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

大家可以先想想

流程分析

本题中,可以每次可以走 1 级,也可以一次走 2 级,因此我们会有 3 种走法:

  • 全程任意走,如全部 1 级走;
  • 前面任意走,最后一步只走 1 级;
  • 前面任意走,最后一步只走 2 级;

我画了几张图方便大家理解,如下:

第一种走法就不做详细介绍。

第二种走法,倒数第二步的走法如下,有 1 步和 2 步两种方式:

第三种走法,倒数第二步的走法如下,也有 1 步和 2 步两种方式:

上面这个过程描述的是,从最后一层开始往下的每一层的走法。

在最后一步时,有 1 步和 2 步两种方式,可以理解为只能 1 步或者 2 步到达最后一层。

  • 当最后一步为 1 步时,即从 n-1 层开始;
  • 当最后一步为 2 步时,即从 n-2 层开始;
  • 假设我爬1层还剩2 假设我爬2还剩1 那就是求 爬1级 和爬2级共有多少种 这个已知的

再理解一下这个过程,就是第 n 层的走法数量是第 n-1 层和第 n-2 层走法数量之和。

如果还不太理解,可以再看看前面的图。

归纳法分析

当然,遇事不决,归纳法走起,我们可以列举几种情况进行分析:

台阶层数走法数量走法
111
2211、2
33111、12、21
451111、112、121、211、22
5811111、1112、1121、1211、2111、221、212、122
.........

可以发现有个简单的规律,当台阶层数为 n 层,它的走法数量就有 n-1 层的走法数量加上 n-2 层的走法数量。

记做:f(n)=f(n-1)+f(n-2)

想象一下,你站在楼梯的底部,楼梯顶部有n个台阶。你可以选择每次走1个台阶或者2个台阶。问题是,你有多少种不同的方法可以走到顶部。

为什么是斐波那契数列?

  1. 第一步:如果你现在只有1个台阶(n=1),你只有一种方法,那就是直接走上去。所以,f(1)=1。
  2. 第二步:如果你有2个台阶(n=2),你有两种方法:先走1个台阶再走1个台阶,或者直接走2个台阶。所以,f(2)=2。

推导过程:

  • 当你走到第3个台阶(n=3)时,你可以从第1个台阶走两个2个台阶上来,或者从第2个台阶走一个1个台阶上来。所以,f(3)=f(2)+f(1)
  • 同理,当你走到第4个台阶(n=4)时,你可以从第2个台阶走两个2个台阶上来,或者从第3个台阶走一个1个台阶上来。所以,f(4)=f(3)+f(2)

这个逻辑可以一直延续下去,每次你到达一个新的台阶,你可以选择从上一个台阶走1步上来,或者从上上一个台阶走2步上来。这就是为什么这个问题的解法是斐波那契数列,因为每一步的解都依赖于前两步的解。

简单来说,爬楼梯问题就像是你在玩一个数字游戏,每一步的“分数”都是前两步“分数”的和。这就是为什么我们说爬楼梯问题是斐波那契数列的一个实际应用。

解法1:循环累加计算

通过简单的循环累加就能得到结果:

const climbStairs = (n = 1) => {if (n <= 2) return n;let res = 0,n1 = 1,n2 = 2; // n1 表示前 2 项,n2 表示前 1 项for (let i = 3; i <= n; i++) {// 前两项值固定,因此从第 3 项开始循环res = n1 + n2;n1 = n2;n2 = res;}return res;
};

解法2:递归计算

按照 f(n)=f(n-1)+f(n-2),这个方法更加简单:

const climbStairs = (n = 1) => {if (n <= 2) return n;return climbStairs(n - 1) + climbStairs(n - 2);
};

这个方法比较简洁易懂,但递归比较费时,容易出现 LeetCode 超出时间限制的提示。

解法3:利用数组特性

利用 f(n)=f(n-1)+f(n-2) 这个规律,先预设好前 2 项,再开始循环,最后返回数组最后一项即可:

const climbStairs = (n) => {let result = [1, 2];for (let i = 2; i < n; i++) {result.push(result[i - 1] + result[i - 2]);}return result[n - 1];
};

解法4:利用 JavaScript ES6 新特性

利用数组结构赋值操作: [a, b] = [c, d]

const climbStairs = n => {let a = b = 1;for (let i = 0; i < n; i++) {[a, b] = [b, a + b];}return a;
};

拓展知识:每次可以走 1 步、2 步、3 步

这里多增加了一次可以走 3 步,这时候最后一步会有以下情况:

  • 当最后一步为 1 步时,即从 n-1 层开始;
  • 当最后一步为 2 步时,即从 n-2 层开始;
  • 当最后一步为 3 步时,即从 n-3 层开始;

改造一下前面解法,还是一样:

const climbStairs = (n = 1) => {if(n <= 2) return n;if(n == 3) return 4;return climbStairs(n-1) + climbStairs(n-2) + climbStairs(n-3);
}

拓展知识:斐波那契数列

这一题主要考察的内容类似斐波那契数列(Fibonacci sequence)的计算,如果你还不清楚什么是斐波那契数列,这边先简单介绍一下,另外推荐

最早是有由数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)以兔子繁殖为例子而引入的,数列大致如:0、1、1、2、3、5、8、13、21、34、....。
认真观察,我们可以发现一个规律:从第 3 项开始,每一项的值都等于前两项之和

在自然界中,存在着许许多多的斐波那契数列的排列方式,比如一棵普通的树,它的树枝生长情况就像下面这样:

1.jpg

可以看到每一层枝干的数量为 1、2、3、5、8、...排列下去。当然还有很多其他的:

根据斐波那契数列的规律,得到这样的公式 f(n)=f(n-1)+f(n-2) 。跟我们前面列的差不多。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/406719.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ClickHouse实时探索与实践 京东云

1 前言 京喜达技术部在社区团购场景下采用JDQFlinkElasticsearch架构来打造实时数据报表。随着业务的发展 Elasticsearch开始暴露出一些弊端&#xff0c;不适合大批量的数据查询&#xff0c;高频次深度分页导出导致ES宕机、不能精确去重统计&#xff0c;多个字段聚合计算时性能…

位运算专题

分享丨【题单】位运算&#xff08;基础/性质/拆位/试填/恒等式/思维&#xff09; - 力扣&#xff08;LeetCode&#xff09; Leetcode 3133. 数组最后一个元素的最小值 我的答案与思路&#xff1a; class Solution { public: // 4 --> (100)2 7 --> (0111)2 // 5 --&g…

怎么让FLV转MP4?建议试试这样做

怎么让FLV转MP4&#xff1f;在数字视频处理的日常中&#xff0c;我们经常会遇到不同格式的视频文件需要相互转换的情况。FLV&#xff08;Flash Video&#xff09;作为一种早期的网络视频格式&#xff0c;虽然在互联网上仍有一定应用&#xff0c;但对比来说&#xff0c;MP4格式更…

vue打包设置 自定义的NODE_ENV

默认NODE_ENV 自定义process.env.NODE_ENV的值_process.node.env的值-CSDN博客 ‌NODE_ENV开发环境下&#xff1a;NODE_ENVdevelopment(默认) 生产环境下&#xff1a;NODE_ENVproduction(默认) NODE_ENV 除了默认的 development 和 production 以外&#xff0c;确实可以自定义…

Apache CloudStack Official Document 翻译节选(八)

关于 Apache CloudStack 的 最佳实践 &#xff08;二&#xff09; 防火墙的设定 Hardware Firewall 部署Apache CloudStack时&#xff0c;建议部署一套防火墙系统已保护Apache CloudStack的云管理服务。在防火墙的选用方面&#xff0c;既可以使用通用防火墙、也可以使用诸如Ju…

树莓派3B运行rasa init和rasa shell遇到的tensorflow报错总结

终于在我的树莓派上安装rasa-1.4.0版本成功&#xff08;见《树莓派智能语音助手之聊天机器人-RASA》&#xff09;。不过&#xff0c;在初始化rasa的时候还是遇到了很多报错&#xff0c;在此总结&#xff0c;供朋友们参考。 1. ModuleNotFoundError: No module named ‘tensorf…

【鸿蒙学习】HarmonyOS应用开发者高级认证 - 应用性能优化一(界面层面)

学完时间&#xff1a;2024年8月22日 学完排名&#xff1a;第1801名 一、介绍 在开发HarmonyOS应用时,优化应用性能是至关重要的。通过/ArkTS高性能编程、减少丢帧卡顿、提升应用启动和响应速度 可以有效提升用户体验。本文将介绍一些优化HarmonyOS应用性能的方法。 一、Ark…

Windows-Server-2016/2019绕过WindowsDefender

当获得了一个webshell的时候&#xff0c;下一步要反弹个shell回来 在尝试了https://github.com/trustedsec/unicorn独角兽失败之后&#xff0c;找到了一篇使用golang将shellcode注入到内存的文章 Bypassing Antivirus with Golang - Gopher it! | JUMPSEC LABS GitHub - brimst…

谷粒商城实战笔记-213-商城业务-认证服务-整合短信验证码服务

文章目录 一&#xff0c;开通阿里云云市场短信服务1&#xff0c;阿里云开通免费短信服务并调试2&#xff0c;整合短信服务2.1 下载HttpUtils代码2.2 开发调用短信服务的组件2.3 测试 HttpUtils代码 这一节主要内容是整合短信发送服务。 一&#xff0c;开通阿里云云市场短信服务…

Wemos D1 Mini pro/ nodeMcu / ESP8266 驱动 240*320 ILI9431 SPI液晶屏

Wemos D1 Mini / nodeMcu / ESP8266 驱动 240*320 ILI9431 SPI液晶屏 效果展示器件硬件连接引脚连接原理图引脚对照表 安装TFT_eSPI库TFT_eSPI库中User_Setup.h文件的参数修改User_Setup.h文件的位置User_Setup.h文件中需要修改的参数User_Setup.h完成源码 例程 缘起&#xff1…

【MySQL】半同步模式

1 半同步模式原理 1. 用户线程写入完成后 master 中的 dump 会把日志推送到 slave 端 2.slave 中的 io 线程接收后保存到 relaylog 中继日志 3. 保存完成后 slave 向 master 端返回 ack 4. 在未接受到 slave 的 ack 时 master 端时不做提交的&#xff0c;一直处于等待当收到…

秃姐学AI系列之:AlexNet + 代码实现

目录 深度学习之前的网络 机器学习 几何学 特征工程 总结 深度卷积神经网络的突破的两个关键因素 数据 ImageNet&#xff08;2010&#xff09; 硬件 90年&#xff1a;数据量和计算能力发展的均匀且都不大的时候——神经网络 00年&#xff1a;内存不错、算力也不错&a…

docker-compose安装NebulaGraph 3.8.0

文章目录 一. 安装NebulaGraph1.1 通过 Git 克隆nebula-docker-compose仓库的3.8.0分支到主机1.2 部署1.3 卸载1.4 查看 二. 安装NebulaGraph Studio2.1 下载 Studio 的部署配置文件2.2 创建nebula-graph-studio-3.10.0目录&#xff0c;并将安装包解压至目录中2.3 解压后进入 n…

【鸿蒙学习】HarmonyOS应用开发者高级认证 - 应用性能优化二(代码层面)

学完时间&#xff1a;2024年8月22日 学完排名&#xff1a;第1801名 一、长列表优化概述 列表是应用开发中最常见的一类开发场景&#xff0c;它可以将杂乱的信息整理成有规律、易于理解和操作的形式&#xff0c;便于用户查找和获取所需要的信息。应用程序中常见的列表场景有新…

IDEA 导入 RocketMQ 源码

目录 前言一、RocketMQ 架构二、环境准备三、下载源码四、编译源码4.1 导入源码4.2 目录结构4.3 运行程序1. 启动 Namesrv2. 启动 Broker3. 启动 Producer4. 启动 Consumer 五、监控平台的搭建5.1 下载 console 源码5.2 IDEA 启动 前言 最近项目中有个功能需要在本地调试下 Ro…

验证实战知识点--(2)

1.seq中的pre_start pre_start 是 uvm_sequence 类的一个虚拟方法&#xff0c;用于在序列开始执行之前进行初始化和设置。这个方法在调用 start 方法前立即执行&#xff0c;提供了一个执行自定义初始化代码的机会。 start 方法用于启动序列的执行&#xff0c;而 pre_start 可以…

【MySQL】数据库基础(库的操作)

目录 一、MySQL安装、连接、修改密码操作 二、库的操作 2.1 创建数据库 2.2 字符集和校验规则 2.3 操控数据库 2.4 修改数据库 2.5 删除数据库 2.6 数据库的备份和恢复 2.7 查看连接情况 前情提要&#xff1a; 我的服务器操作系统是Ubuntu20.04&#xff0c;安装的是M…

06--kubernetes.pod管理与投射数据卷

前言&#xff1a;上一章记录了部署k8s常用的两个方式&#xff0c;这一章就简单一些&#xff0c;整理一下k8s资源对象的配置和管理命令。 1、集群状态检查 前天搭建的环境&#xff0c;然后关机了两天今天开启后第一时间需要检查集群环境是否正常 [rootk8s-master1 ~]# kubect…

探索《黑神话·悟空》背后的AI技术支持:英伟达全景光线追踪技术、DLSS 3.5 与帧生成

引言 2023 年&#xff0c;游戏《黑神话悟空》以其震撼的视觉效果和深度沉浸的游戏体验&#xff0c;成为全球玩家热议的焦点。这款游戏在发布初期就取得了惊人的销量&#xff1a;预售阶段便突破 120 万套&#xff0c;而发售首日更是达到 450 万份的惊人成绩。这个现象级作品背后…

大模型微调课程及大模型应用开发课程介绍

大模型实验室是在学校现有的实验室建设基础上&#xff0c;依托行业标杆企业&#xff0c;聚焦行业大模型产业发展方向&#xff0c;建设一个产学研一体化的合作教学平台&#xff0c;形成“教与学紧密结合、理论与实践紧密结合&#xff0c;学校与企业紧密结合”的创新教育模式。大…