Leetcode-每日一题【剑指 Offer 10- II. 青蛙跳台阶问题】

题目

一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。

答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。

示例 1:

输入: n = 2
**输出:**2

示例 2:

输入: n = 7
**输出:**21

示例 3:

输入: n = 0
**输出:**1

提示:

0 <= n <= 100

解题思路

1.题目要求我们求出该青蛙跳上一个 n 级的台阶总共有多少种跳法,这道题跟斐波那契数列有着同样的思路,f(n) = f(n-1) + f(n-2),至于为什么是这样我们一起来看一下图

举个例子:假设我们有五层台阶

我们可以看到第五层台阶的跳法就是f(3)和f(4)跳法的总和,只不过在每一种跳法后面加了个5而已,这跟斐波那契数列如出一辙,所以我们使用斐波那契数列的做法解决这个问题。

3.首先如果青蛙只想上第一个台阶或第零个台阶那么他的跳法就是 1,我们直接return 1,然后我们设置三个变量a、b、c,

a指向第0个台阶的跳法,b指向第一个台阶的跳法,c指向第二个台阶的跳法,那么 c = a + b , 之后我们让a = b,b = c 。

c = a + b 这样我们就得到了第三个台阶的跳法,以此类推,直到 c 指向了 n,我们就得到了第 n 个台阶的跳法。

代码实现

java 复制代码
class Solution {
    public int numWays(int n) {
        if(n <= 1){
            return 1;
        }
        int a = 1;
        int b = 1;
        int c = 0;
        for(int i = 2; i <= n; i++){
            c = (a + b) % 1000000007;
            a = b;
            b = c;
        }
        return c;

    }
}

测试结果

相关推荐
地平线开发者15 小时前
PTQ 量化数值范围与优化
算法·自动驾驶
sali-tec15 小时前
C# 基于halcon的视觉工作流-章68 深度学习-对象检测
开发语言·算法·计算机视觉·重构·c#
测试人社区-小明15 小时前
智能弹性伸缩算法在测试环境中的实践与验证
人工智能·测试工具·算法·机器学习·金融·机器人·量子计算
Spring AI学习15 小时前
Spring AI深度解析(9/50):可观测性与监控体系实战
java·人工智能·spring
罗西的思考16 小时前
【Agent】MemOS 源码笔记---(5)---记忆分类
人工智能·深度学习·算法
java1234_小锋16 小时前
Spring IoC的实现机制是什么?
java·后端·spring
xqqxqxxq17 小时前
背单词软件技术笔记(V2.0扩展版)
java·笔记·python
消失的旧时光-194317 小时前
深入理解 Java 线程池(二):ThreadPoolExecutor 执行流程 + 运行状态 + ctl 原理全解析
java·开发语言
哈哈老师啊17 小时前
Springboot学生综合测评系统hxtne(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
java·数据库·spring boot
4311媒体网17 小时前
帝国cms调用文章内容 二开基本操作
java·开发语言·php