当前位置:网站首页>力扣——青蛙跳台阶问题
力扣——青蛙跳台阶问题
2022-08-11 04:13:00 【cbys-1357】
题目:
一只青蛙一次可以跳上1级台阶,也可以跳上2级台阶。求该青蛙跳上一个 n 级的台阶总共有多少种跳法。
答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。
示例 1:
输入:n = 2
输出:2示例 2:
输入:n = 7
输出:21示例 3:
输入:n = 0
输出:1设跳上 n 级台阶有 f(n) 种跳法。在所有跳法中,青蛙的最后一步只有两种情况: 跳上 1 级或 2级台阶。
当为 1 级台阶: 剩 n−1 个台阶,此情况共有 f(n−1) 种跳法;
当为 2 级台阶: 剩 n−2 个台阶,此情况共有 f(n−2) 种跳法。
f(n) 为以上两种情况之和,即 f(n)=f(n−1)+f(n−2) ,以上递推性质为斐波那契数列。本题可转化为 求斐波那契数列第 n 项的值 ,与 斐波那契数列 等价,唯一的不同在于起始数字不同。
青蛙跳台阶问题: f(0)=1 , f(1)=1 , f(2)=2
斐波那契数列问题: f(0)=0 , f(1)=1 , f(2)=1 class Solution {
public int numWays(int n) {
int a = 1, b = 1, sum;
for(int i = 0; i < n; i++){
sum = (a + b) % 1000000007;
a = b;
b = sum;
}
return a;
}
}
博主本人把这道题题解放到,不是表达这道题很难,用了什么高级的算法来绝决,而是提醒自己,自己有多么多么笨,在第一下看到这道题的时候,我的内心一直想的是什么排列组合,来计算有多少种,而且还出现错误,想想自己,。。。,害,把这题题解放到我的一篇文章中,是提醒自己,别把自己蠢死了,越学越笨。。。说句实话,我确实一直没有想到,最后还是看解析才知道。原来是这样子。
最后到这也就结束,在此谢谢大家能够阅读到最后,非常感谢!!!
边栏推荐
- leetcode刷题第13天二叉树系列之《98 BST及其验证》
- 【服务器安装Redis】Centos7离线安装redis
- 「转」“搜索”的原理,架构,实现,实践,面试不用再怕了
- .NET service registration
- Get Qt installation information: including installation directory and various macro addresses
- The custom of the C language types -- -- -- -- -- - structure
- MySQL database storage engine and database creation, modification and deletion
- uni-app - 获取汉字拼音首字母(根据中文获取拼音首字母)
- How to delete statements audit log?
- The last update time of the tables queried by the two nodes of the rac standby database is inconsistent
猜你喜欢

【FPGA】day22-SPI protocol loopback

【FPGA】名词缩写

"98 BST and Its Verification" of the 13th day of leetcode brushing series of binary tree series

Graphical LeetCode - 640. Solving Equations (Difficulty: Moderate)

Clang Code Model: Error: The clangbackend executable “X:/clangbackend.exe“ could not be started

破解事务性工作瓶颈,君子签电子合同释放HR“源动力”!

"239 Sliding Window Maximum Value" on the 16th day of LeetCode brushing

获取Qt的安装信息:包括安装目录及各种宏地址

使用jackson解析json数据详讲

机器学习中什么是集成学习?
随机推荐
【FPGA】day22-SPI protocol loopback
Day20 FPGA 】 【 - block the I2C read and write EEPROM
一文读懂 高性能可预期数据中心网络
洛谷P4560 Wall 砖墙
LeetCode Brush Questions Day 11 String Series "58 Last Word Length"
FTP错误代码列表
Basic understanding of MongoDB (2)
什么是机器强化学习?原理是什么?
【FPGA】设计思路——I2C协议
"110 Balanced Binary Tree Judgment" in leetCode's 14-day binary tree series
每日一题-滑动窗口
LeetCode刷题第12天二叉树系列之《104 二叉树的最大深度》
【FPGA】SDRAM
JVM 垃圾回收的概述与机制
洛谷P4324 扭动的回文串
【FPGA】abbreviation
【FPGA】day19-二进制转换为十进制(BCD码)
Alibaba Cloud releases 3 high-performance computing solutions
洛谷P2150 寿司晚宴
【FPGA】名词缩写