递归(python实现)

# 递归法获取最大值
class GetMax:
    # 求arr中的最大值
    def get_max(self, arr):
        return self.process(arr, 0, len(arr)-1)

    # arr[l...r]范围上求最大值
    def process(self, arr, l, r):
        # arr[l...r]范围上只有一个数,直接返回
        if l == r:
            return arr[l]
        mid = l + ((r-l) >> 1)  # 中点
        left_max = self.process(arr, l, mid)
        right_max = self.process(arr, mid+1, r)
        return max(left_max, right_max)

递归用到了系统栈,如下图。系统栈会记录下一些必要的信息放入系统栈中,返回结果时会将结果返回到栈顶,然后继续执行。
在这里插入图片描述
有一种递归是可以直接计算时间复杂度的,如图
只要满足下面公式,其中以上面代码为例,则,a为有几个子过程,此时也就是求left_max 和right_max ,则a=2;b为子过程的范围,也就是N/2 则此时b= 2, d为除子过程外剩下的时间复杂度,此时为常数时间复杂度,也就是O(1)则d=0
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值