-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path53-最大子序和.cpp
68 lines (57 loc) · 1.51 KB
/
53-最大子序和.cpp
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/*
给定一个整数数组 nums ,找到一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。
示例:
输入: [-2,1,-3,4,-1,2,1,-5,4]
输出: 6
解释: 连续子数组 [4,-1,2,1] 的和最大,为 6。
*/
#include<iostream>
using namespace std;
#include<vector>
class Solution{
public:
int maxSubArray(vector<int>& nums){
/*
动态规划
*/
int pre = 0, maxAns = nums[0];
for (const auto &x:nums){
pre = max(pre+x, x);
maxAns = max(maxAns, pre);
}
return maxAns;
}
};
class Solution2{
/*
线段树, 详情见 https://leetcode-cn.com/problems/maximum-subarray/solution/zui-da-zi-xu-he-by-leetcode-solution/
*/
public:
struct Status
{
int lSum, rSum, mSum, iSum;
};
Status pushUp(Status l, Status r)
{
int iSum = l.iSum + r.iSum;
int lSum = max(l.lSum, l.iSum + r.lSum);
int rSum = max(r.rSum, r.iSum + l.rSum);
int mSum = max(max(l.mSum, r.mSum), l.rSum + r.lSum);
return (Status){lSum, rSum, mSum, iSum};
};
Status get(vector<int> &a, int l, int r)
{
if (l == r)
{
return (Status){a[l], a[l], a[l], a[l]};
}
int m = (l + r) >> 1;
Status lSub = get(a, l, m);
Status rSub = get(a, m + 1, r);
return pushUp(lSub, rSub);
}
int maxSubArray(vector<int> &nums)
{
return get(nums, 0, nums.size() - 1).mSum;
}
};