1
1
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/linear

This commit is contained in:
Divlo 2022-05-01 18:44:07 +02:00
parent 2b6ace9eb5
commit ca5d3a5a55
No known key found for this signature in database
GPG Key ID: 8F9478F220CE65E9
2 changed files with 29 additions and 0 deletions

View File

@ -0,0 +1,3 @@
# maximum-subarray-sum/python/linear
Created by [@Divlo](https://github.com/Divlo) on 1 May 2022.

View File

@ -0,0 +1,26 @@
import sys
def maximum_subarray_sum_linear(array: list[int]) -> int:
"""
Time complexity: O(array_length)
We loop through the array and for each array position, we calculate the maximum sum of a subarray that ends at that position. After this, the answer for the problem is the maximum of those sums.
"""
if len(array) == 0:
return 0
best_sum = array[0]
length = len(array)
sum = 0
for i in range(length):
sum = max(array[i], sum + array[i])
best_sum = max(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_linear(numbers))