题目:一只青蛙一次可以跳上1级台阶,也可以跳上2级……它也可以跳上n级。求该青蛙跳上一个n级的台阶总共有多少种跳法。
思路1:
因为n级台阶,第一步有n种跳法:跳1级、跳2级、...... 到跳n级
跳1级,剩下n-1级,则剩下跳法是f(n-1)
跳2级,剩下n-2级,则剩下跳法是f(n-2)
所以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) (n>=2);==》f(n)=2^(n-1)*f(1)==》f(n)=2^(n-1).
思路2:
因为n级台阶,最后一级台阶是必须要跳到的一个台阶--目的台阶。
剩下n-1个台阶为辅助台阶,有跳到和跳不到两种情况。
所以总共有2^(n-1)种跳法。
Java代码:
public class Solution
{
public int JumpFloorII(int target)
{
//判断参数是否合法
if (target <= 0)
{
return -1;
}
//用有符号左移来模拟2的(n-1)次方
else
{
return 1<<(target-1);
}
}
}