递归之台阶问题
2015-04-27 18:16
260 查看
跳台阶
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。解题思路
当n=1时,次数f(n)=1。当n=2时,次数f(n)=2。(11或2)
当n>2时,当前一步可以跳一级,也可以跳两级,次数f(n)=f(n-1)+f(n-2)。
实现代码
class Solution { public: int jumpFloor(int number) { if (number <= 2) return number; else return jumpFloor(number - 1) + jumpFloor(number - 2); } };
变态跳台阶
一只青蛙一次可以跳上1级台阶,也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。解题思路
当台阶数为n时,可以分为以下步骤来完成:设第一次跳的台阶数为s,跳台阶方式数为T,则:
(1)s=1时,T(n) = T(n-1)
(2)s=2时,T(n) = T(n-2)
.
.
.
(n)s=n时,T(n) = T(0) = 1
所以总的跳台阶方式数T可以表示为:
T(n) = T(0) + T(1) + T(2) + … + T(n-1)
由于T(0) = T(1) = 1,所以T(n) = 2^(n-1)
实现代码
class Solution { public: int jumpFloorII(int number) { return pow(2, number - 1); } };
相关文章推荐
- 奇妙的递归程序-----台阶问题
- 青蛙跳台阶问题的递归思路
- 跳台阶问题(递归)
- 跳台阶问题+变态跳台阶问题(动态递归+非递归)
- No27、跳台阶问题(递归)
- 递归 ( 快速排序算法 ,台阶问题 ,阶乘问题 )
- 使用C++递归求解跳台阶问题
- 跳台阶问题 + 变态跳台阶问题 解法(动态规划递归 + 非递归)
- 递归大总结之台阶问题
- 递归----------上台阶问题
- 递归大总结之n台阶问题
- 递归的logN的优化(菲波那契数列,青蛙上台阶问题,母牛问题)!!!!
- 菲波那切数列的递归与非递归解法以及青蛙跳台阶问题
- 普及练习场 递推与递归二分 台阶问题
- 剑指offer--跳台阶(递归问题)
- 台阶问题递归优化
- 【编程题目】跳台阶问题(递归)
- 跳台阶问题|斐波那契|递归
- 分别使用一般递归的方法和模板元编程实现台阶问题。
- 递归:跳台阶问题