09.变态跳台阶 Java
2020-01-13 01:17
120 查看
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
思路
0:0 1:(1) 2:(1,1)(2) 3:(1,1,1)(2,1)(1,2)(3) 4:(1,1,1,1)(2,1,1)(1,2,1)(3,1)(1,1,2)(1,3)(2,2)(4) 显然,除了0,其他都是2^(n-1); OJ并未检查小于等于0的情况,所以也可将该界外判断去掉。
n级台阶,第一步有n种跳法:1,2,3,...,n 跳1级,剩下的有F(n-1)种。 跳2级,剩下的有F(n-2)种。 ... 跳n级,剩下的有F(0)=1种。 所以F(n)=F(n-1)+F(n-2)+...+F(0) 因为F(n-1)=F(n-2)+F(n-3)+...+F(0) 所以F(n)=2*F(n-1)
代码
public class Solution { public int JumpFloorII(int target) { if(target <= 0){ return 0; } int temp=1; while(target >=2){ temp *=2; target--; } return temp; } }
public class Solution { public int JumpFloorII(int target) { if(target <= 0){ return 0; } return (int)Math.pow(2,target-1); } }
public class Solution { public int JumpFloorII(int target) { if(target <= 0){ return 0; } return 1 << (target -1); } }
public class Solution { public int JumpFloorII(int target) { if(target <= 0){ return 0; }else if(target == 1){ return 1; } return 2*JumpFloorII(target-1); } }
转载于:https://www.cnblogs.com/feicheninfo/p/10522571.html
- 点赞
- 收藏
- 分享
- 文章举报
相关文章推荐
- Java变态跳台阶实现思路和代码
- 【java】变态跳台阶
- 《剑指offer2》问题10 青蛙跳台阶&&变态跳台阶 Java实现
- JAVA实现变态跳台阶问题(《剑指offer》)
- 剑指Offer_09_变态跳台阶
- 剑指Offer---Java实现跳台阶和变态跳台阶
- 剑指Offer [09] 变态跳台阶
- 剑指offer---变态跳台阶(Java)
- 牛客网-剑指offer-09-变态跳台阶
- 【剑指offer——JAVA实现】变态跳台阶
- 《剑指offer》牛客网java题解-变态跳台阶
- 剑指Offer:变态跳台阶(java版)
- 剑指offer-09-变态跳台阶
- 变态跳台阶(java版)
- JAVA实现变态跳台阶问题(《剑指offer》)
- 09.变态跳台阶
- 【剑指offer】二,变态跳台阶(java实现)
- 变态跳台阶java实现
- 剑指offer-跳台阶and变态跳台阶and矩形覆盖-Java
- 剑指offer(java代码)——变态跳台阶