在Python中查找任何子数组的最大绝对和的程序
假设我们有一个名为nums的数组。我们必须找到子数组[nums_l,nums_l+1,...,nums_r-1,nums_r]的绝对和为|nums_l+nums_l+1+...+nums_r-1+nums_r|。我们必须找到nums的任何子数组的最大绝对和(该子数组可能为空)。
因此,如果输入类似于nums=[2,-4,-3,2,-6],那么输出将为11,因为子数组[2,-4,-3,2]具有最大绝对子数组和|2+(-4)+(-3)+2|=11。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums):
n=len(nums)
ans=0
temp=0
for i in range(n):
if (temp<0):
temp=0
temp=temp+nums[i]
ans=max(ans,abs(temp))
temp=0
for i in range(n):
if (temp>0):
temp=0
temp=temp+nums[i]
ans=max(ans,abs(temp))
return ans
nums = [2,-4,-3,2,-6]
print(solve(nums))输入
[2,-4,-3,2,-6]输出结果
11
热门推荐
10 八一幼儿祝福语大全简短
11 公司乔迁食堂祝福语简短
12 婚礼结束聚餐祝福语简短
13 儿媳买车妈妈祝福语简短
14 毕业送礼老师祝福语简短
15 同事辞职正常祝福语简短
16 恭贺新婚文案祝福语简短
17 金店立秋祝福语简短英文
18 婆婆高寿祝福语大全简短