题目描述
一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
做法
由于一次可以跳1、2、3、4…n节台阶,因此
f(n) = f(n-1) + f(n-2) + f(n-3) + …f(n-n);
把式子倒过来看就是f(n) = f(0) + f(1) + f(2) + …+f(n-2) + f(n-1) (1)
那么f(n-1) = f(0) + f(1) + f(2) + … f(n-2) (2)
由(1)(2)可得 f(n) = 2 * f(n-1)
做法来源:传送门
本人的想法比较烂,写了个动态规划记忆化搜索,仅供参考。
大神代码
public int JumpFloorII(int target) {
if (target <= 0) {
return -1;
} else if (target == 1) {
return 1;
} else {
return 2 * JumpFloorII(target - 1);
}
}
我的代码
int[] f = new int[40];
public int JumpFloorII(int target) {
if(f[target] != 0)
return f[target];
if(target == 1 || target == 0)
return 1;
if(target == 2)
return 2;
int ans = 0;
for (int i = 1; i <= target; i++) {
ans += JumpFloorII(target - i);
}
return f[target] = ans;
}