題目描述:
解題思路:
使用動態規劃進行解題。
- 用s表示包含當前元素nums[i]的最大和,result表示迄今爲止的最大和,即s一定要包含nums[i],而result不一定包含nums[i]。初始化s=result=nums[0]
- 如果s>0,說明s對於當前元素具有增益效果,則更新s=s+nums[i]
- 如果s<=0,說明s對於當前元素不具有增益效果,則更新s=nums[i]
- 此時迄今爲止的最大和爲s和result中的最大值,即result=max(result, s)
複雜度分析:
由於只需要遍歷一次數組,所以時間複雜度爲o(n)
空間複雜度爲o(1)
python代碼:
class Solution(object):
def maxSubArray(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
if not nums:
return None
s = result = nums[0]
for i in range(1, len(nums)):
s = s + nums[i] if s > 0 else nums[i]
result = max(result, s)
return result