根据上一个题目:青蛙只跳1或2可以得出是一个斐波那契问题,即a[n]=a[n-1]+a[n-2],那么能跳1,2,3个台阶时a[n]=a[n-1]+a[n-2]+a[n-3]…依次类推,能推出本题的a[n]=a[n-1]+a[n-2]+…+a[1]
所以f(n)=f(n-1)+f(n-2)+…+f(1)
因为f(n-1)=f(n-2)+f(n-3)+…+f(1)
两式相减得到:f(n)=2*f(n-1)
public class Solution {
public int JumpFloorII(int number) {
int f=1,fn=1;
for(int i=2;i<=number;i++){
fn=2*f;
f=fn;
}
return fn;
}
}