在Python中以m为模求子数组的最大和的程序
在Python中以m为模求子数组的最大和的程序
假设我们有一个包含n个元素的数组nums。我们还有另一个整数m。我们必须找到以m为模的任何子数组的和的最大值。
因此,如果输入类似于nums=[1,5,7,3]m=5,那么输出将为3,因为
[1]模5=1
[5]模5=0
[7]模5=2
[3]模5=3
[1,5]模5=1
[5,7]模5=2
[7,3]模5=0
[1,5,7]模5=3
[5,7,3]模5=0
[1,5,7,3]模5=1
示例
让我们看看以下实现以获得更好的理解-
import bisect
def solve(nums, m):
csum = [nums[0] % m]
for x in nums[1:]:
csum.append((csum[-1] + x) % m)
seen = [0]
max_sum = -1
for s in csum:
idx = bisect.bisect_left(seen, s)
if idx < len(seen):
max_sum = max(max_sum, s, (s - seen[idx]) % m)
else:
max_sum = max(max_sum, s)
bisect.insort_left(seen, s)
return max_sum
nums = [1,5,7,3]
m = 5
print(solve(nums, m))输入
"pptpp", [(1,1),(1,4),(1,1),(0,2)]输出结果
3