最大子段和解法及python实现

问题描述:

最大子段和(Maximum Interval Sum):给定长度为n的整数序列,a[1…n], 求[1,n]某个子区间[i , j],使得a[i]+…+a[j]和最大.
例如(-2,11,-4,13,-5,2)的最大子段和为20,所求子区间为[2,4].

求解方法:

1.穷举法
1.1 对起点,终点全部遍历求和依次比较,最傻 的穷举O(n3)
代码:

最大子段和(穷举法)
def maxrange(a):
    n=len(a)
    start=0
    end=0
    Max=0.0
    for i in range(n):
        for j in range(i,n):
            Sum=0
            for k in range(i,j+1):
                Sum=Sum+a[k]
            if(Sum>Max):
                Max=Sum
                start=i+1
                end=j+1
    print(start,end,Max)     

1.2 稍微改进点,同一个起点,比较不同终点,取一个最大;再换下一个起点,两层循环。O(n2)

#最大子段和(穷举法)
def maxrange(a):
    n=len(a)
    Sum=0.0
    start=0
    end=0
    Max=0.0
    for i in range(n):
        Sum=0.0
        for j in range(i,n):
            Sum=Sum+a[j]           
            if(Sum>Max):
                Max=Sum
                start=i+1
                end=j+1
    print(start,end,Max)       
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值