题目浅析

  • 想查看原题可以点击题目链接

  • 简单地说,就是求数组中一段子数组的和的最大值,要求子数组内的元素不重复。

思路分享

代码解答(强烈建议自行解答后再看)

  • 陆爻齐的解法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
class Solution {
public:
int maximumUniqueSubarray(vector<int>& nums) {
int sum = 0;
int ans = 0;
int left = 0;
unordered_map<int, int>rec;
int n = nums.size();
for (int i = 0; i < n; i++) {
int m = nums[i];
sum += m;
rec[m]++;
while(rec[m]>1) {
sum -= nums[left];
rec[nums[left++]]--;
}
ans = max(sum, ans);
}
return ans;
}
};