青蛙跳台阶

青蛙跳台阶,每次能跳一阶或者两阶,问n阶有多少种跳法
可以把问题转化成n的跳法等于n-1阶和n-2阶的跳法和。

fib = lambda n:n if n<=2 else fib(n-1)+fib(n-2)

变态青蛙跳,每次能跳一阶,两阶,…,n阶,问n阶有多少种跳法
问题可以考虑成:
fib(n) = fib(n-1) +fib(n-2) + …+fib(1)
fib(n-1) =fib(n-2) +fib(n-3) + …+fib(1)
所以:fib(n)-fib(n-1) = fib(n-1)
所以:fib(n) = 2*fib(n-1)

fib = lambda n:n if n<2 else 2*fib(n-1)

代码:
解法一:

class Solution:
    @cache
    def jumpFloorII(self, number):
        # write code here
        if number ==1:
            return 1
        if number ==0:
            return 1
        return 2*self.jumpFloorII(number-1)

解法二:
使用装饰器,可以减少计算次数,效率与解法一相同

import functools
def cache(func):
    result = {}
    @functools.wraps(func)
    def wrapper(self,n):
        if result.get(n, 0):
            return result.get(n)
        else:
            result[n] = func(self,n)
            return result[n] 
    return wrapper

class Solution:
    @cache
    def jumpFloorII(self, number):
        # write code here
        if number ==1:
            return 1
        if number ==0:
            return 1
        result = 0
        for i in range(number):
            result += self.jumpFloorII(i)
        return result
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值