最大子数组线性解法(Python)

最大子数组线性解法

问题:

连续的若干数组元素,如果其和是最大的,那么这个子数组就称为该数组的最大子数组。

FindEasy(A)::
    #判断数组A是否为空,为空则返回
    if len(A) < 1:
        return None
    SumMax = A[0]
    SumStart = 0
    start = 0
    SumStop = 0
    sum = 0
    for i in range(0, len(A)-1, 1):
        sum += A[i]
        if sum > SumMax:
            SumStop = i
            SumMax = sum
            SumStart = start
        #最大子数组,如果值大于零,两端的值肯定大于零
        elif sum < 0:
            start = i
            sum = 0
    #判断起点:为len(A) - 1时是数组最后一个元素,且SumStart和SumStop不相等
    if SumStart < len(A) - 1 and SumStart < SumStop - 1:
        SumStart += 1
    return SumStart, SumStop, SumMax
A = (13, -3, -25, 20, -3, -16, -23, 18, 20, -7, 12, -5, -22, 15, -4, 7)
print(A)
print(FindEasy(A))

输出:
(13, -3, -25, 0, -3, -16, -23, 18, 20, -7, 12, -5, -22, -4, 7)
(7, 10, 43)

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值