数据结构三:变态跳台阶 矩阵覆盖

ACM
算法练习题
bingoabin

//变态跳台阶 //一只青蛙一次可以跳上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)

package nowcoder.offer.cn;

/**
 * @author xumaosheng
 * @date 2019/9/9 19:38
 */
public class _09AbnormalJumpSteps {
	public static void main(String[] args) {
		Solution1 solution5 = new _09AbnormalJumpSteps().new Solution1();
		int result = solution5.JumpFloorII(5);
		System.out.println(result);
	}

	public class Solution1 {
		public int JumpFloorII(i
已标记关键词 清除标记
相关推荐
©️2020 CSDN 皮肤主题: 点我我会动 设计师:白松林 返回首页
实付 49.90元
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值