这道题虽然是简单题,但我觉得很有趣,O(n)的思路其实很简单:从第一个元素开始,如果当前元素超过从头到当前所有元素之和,那么就把当前元素作为第一个元素继续遍历:
class Solution:
def maxSubArray(self, nums: 'List[int]') -> 'int':
n = len(nums)
curr_sum = max_sum = nums[0]
for i in range(1, n):
curr_sum = max(nums[i], curr_sum + nums[i])
max_sum = max(max_sum, curr_sum)
return max_sum