【Leetcode】青蛙跳台阶问题

(1)思路:

DP问题:
(1)确定数组含义:dp[i]表示跳到第i阶的方法数;
(2)找出数组元素间的关系:跳到第i阶,可以一步跳上来,也可以两步跳上来,所以dp[i]=dp[i-1]+dp[i-2];
(3)找出初始值:dp[0]=1,dp[1]=1;

代码:

class Solution {
    public int numWays(int n) {
        if(0 == n) 
        	return 1;
        	
        int[] dp = new int[n+1];
        dp[0] = 1;
        dp[1] = 1;
        for(int i = 2; i<n+1; i++)
        {
            dp[i] = (dp[i-1] + dp[i-2]) % 1000000007;
        }

        return dp[n];
    }
}

复杂度分析:

Time:O(N)
Space:O(N)

注意:

(1)由于DP下标的实际意义是1~n,所以数组声明长度为n+1;
(2)第0项并不具有实际意义,可按需调节其值;

(2)方法优化:

数组占用较多空间,三者用变量代替;

代码:

int numWays(int n){
	int a,b,t;

	if(0 == n) return 1;
	if(1 == n) return 1;
	if(2 == n) return 2;

	/* 进入迭代之前,三者必须要有具体值! */
	a = 1;
	b = 2;
	t = a + b;
	
	for(int i = 3; i<n; i++){
		a = b;
		b = t;
		t = (a+b)%1000000007;
	}

	return t;
}

复杂度分析:

Time:O(N)
Space:O(1)

图解:
图解1
图解2

Tips:

Java支持声明并初始化变量长度的数组,自动初始化为0;

C支持声明变量长度的数组,但不能同时初始化,需要另外赋值初始化;

所以,对于数组等数据结构建议用Java,链表建议用C!!!
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值