def MaxCross(A,low,mid,high):
    left_sum=-100000
    sum=0
    for i in range(low,mid+1,1):
        sum=sum+A[i]
        if(sum>left_sum):
            left_sum=sum
            max_left=i
    right_sum=-100000
    sum=0
    for j in range(mid+1,high+1,1):
        sum=sum+A[j]
        if(sum>right_sum):
            right_sum=sum
            max_right=j
    return (max_left,max_right,left_sum+right_sum)

def MaxSum(A,low,high):
    if(high==low):
        return (low,high,A[low])
    else:
        mid=(low+high)//2
        (left_low,left_high,left_sum)=MaxSum(A,low,mid)
        (right_low,right_high,right_sum)=MaxSum(A,mid+1,high)
        (cross_low,cross_high,cross_sum)=MaxCross(A,low,mid,high)
        if(left_sum>=right_sum and left_sum>=cross_sum):
            return (left_low,left_high,left_sum)
        if(right_sum>=left_sum and right_sum>=cross_sum):
            return (right_low,right_high,right_sum)
        else:
            return (cross_low,cross_high,cross_sum)

A=[13,-3,-25,20,-3,-16,-23,18,20,-7,12,-5,-22]
t=MaxSum(A,0,12)
print(t)
