mirror of
https://github.com/theoludwig/programming-challenges.git
synced 2024-10-29 22:17:23 +01:00
feat(solutions): add maximum-subarray-sum/python/cubic
This commit is contained in:
parent
26c468b879
commit
2b6ace9eb5
@ -0,0 +1,3 @@
|
||||
# maximum-subarray-sum/python/cubic
|
||||
|
||||
Created by [@Divlo](https://github.com/Divlo) on 1 May 2022.
|
@ -0,0 +1,29 @@
|
||||
import sys
|
||||
|
||||
|
||||
def maximum_subarray_sum_cubic(array: list[int]) -> int:
|
||||
"""
|
||||
Time complexity: O((array_length)^3)
|
||||
|
||||
We go through all possible subarrays, calculate the sum in each subarray and maintain the maximum sum.
|
||||
"""
|
||||
if len(array) == 0:
|
||||
return 0
|
||||
best_sum = array[0]
|
||||
length = len(array)
|
||||
for i in range(length):
|
||||
for j in range(i, length):
|
||||
sum = 0
|
||||
for k in range(i, j + 1):
|
||||
sum += array[k]
|
||||
if sum > best_sum:
|
||||
best_sum = sum
|
||||
return best_sum
|
||||
|
||||
|
||||
numbers: list[int] = []
|
||||
for value in sys.stdin:
|
||||
numbers.append(int(value.rstrip('\n')))
|
||||
|
||||
numbers = numbers[1:]
|
||||
print(maximum_subarray_sum_cubic(numbers))
|
Loading…
Reference in New Issue
Block a user