-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmax_subarray.py
38 lines (31 loc) · 1022 Bytes
/
max_subarray.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
# Given an integer array nums, find the contiguous subarray (containing at least one number) which has the largest sum and return its sum.
# Example:
# Input: [-2,1,-3,4,-1,2,1,-5,4],
# Output: 6
# Explanation: [4,-1,2,1] has the largest sum = 6.
class Solution(object):
def maxSubArray(self, nums):
"""
:type nums: List[int]
:rtype: int
"""
total = 0
maximum = -999
if len(nums)==1:
return nums[0]
for v in nums:
if v>total:
total=max(total+v,v)
print("great ", total)
elif v<total:
if (total+v)>0:
total=max(total+v,v)
else:
total=max(total+v,v)
print("less ", total)
else:
total=max(total+v,v)
if maximum<total:
maximum = total
return maximum
#[1,2,-1,-2,2,1,-2,1,4,-5,4]