09变态跳台阶(Java)
2020-05-31 18:48
561 查看
题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
解题思路
跳上 n-1 级台阶,可以从 n-2 级跳 1 级上去,也可以从 n-3 级跳 2 级上去…,那么
f(n-1) = f(n-2) + f(n-3) + … + f(0)
同样,跳上 n 级台阶,可以从 n-1 级跳 1 级上去,也可以从 n-2 级跳 2 级上去… ,那么
f(n) = f(n-1) + f(n-2) + … + f(0)
综上可得
f(n) - f(n-1) = f(n-1)
即
f(n) = 2*f(n-1)
所以 f(n) 是一个等比数列,an = a1 * q^(n-1)。
Java实现
方法一:数学推导
public class Solution { public int JumpFloorII(int target) { return (int) Math.pow(2, target - 1); } }
方法二:动态规划
public int JumpFloorII(int target) { int[] dp = new int[target]; Arrays.fill(dp, 1); for (int i = 1; i < target; i++) for (int j = 0; j < i; j++) dp[i] += dp[j]; return dp[target - 1]; }
相关文章推荐
- 09.变态跳台阶 Java
- 09.变态跳台阶
- 剑指offer(java代码)——变态跳台阶
- 剑指Offer---Java实现跳台阶和变态跳台阶
- 【剑指offer——JAVA实现】变态跳台阶
- 【剑指offer】二,变态跳台阶(java实现)
- 变态跳台阶java实现
- 剑指Offer:变态跳台阶(java版)
- 09.变态跳台阶
- 剑指offer-09-变态跳台阶
- 剑指offer---变态跳台阶(Java)
- 【java】变态跳台阶
- 剑指offer-跳台阶and变态跳台阶and矩形覆盖-Java
- 剑指Offer_09_变态跳台阶
- 《剑指offer2》问题10 青蛙跳台阶&&变态跳台阶 Java实现
- JAVA实现变态跳台阶问题(《剑指offer》)
- 剑指Offer [09] 变态跳台阶
- 变态跳台阶(java版)
- Java变态跳台阶实现思路和代码
- 变态跳台阶-剑指Offer(Java语言)