-
Notifications
You must be signed in to change notification settings - Fork 523
/
Copy path28. Maximum Erasure Value.cpp
59 lines (46 loc) · 1.38 KB
/
28. Maximum Erasure Value.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
/*
Maximum Erasure Value
=====================
You are given an array of positive integers nums and want to erase a subarray containing unique elements. The score you get by erasing the subarray is equal to the sum of its elements.
Return the maximum score you can get by erasing exactly one subarray.
An array b is called to be a subarray of a if it forms a contiguous subsequence of a, that is, if it is equal to a[l],a[l+1],...,a[r] for some (l,r).
Example 1:
Input: nums = [4,2,4,5,6]
Output: 17
Explanation: The optimal subarray here is [2,4,5,6].
Example 2:
Input: nums = [5,2,1,2,5,2,1,2,5]
Output: 8
Explanation: The optimal subarray here is [5,2,1] or [1,2,5].
Constraints:
1 <= nums.length <= 105
1 <= nums[i] <= 104
Hint #1
The main point here is for the subarray to contain unique elements for each index. Only the first subarrays starting from that index have unique elements.
Hint #2
This can be solved using the two pointers technique
*/
class Solution
{
public:
int maximumUniqueSubarray(vector<int> &nums)
{
int ans = 0;
int i = 0, j = 0, n = nums.size(), curr = 0;
unordered_set<int> vis;
while (j < n)
{
while (i < j && vis.find(nums[j]) != vis.end())
{
curr -= nums[i];
vis.erase(nums[i]);
i++;
}
vis.insert(nums[j]);
curr += nums[j];
j++;
ans = max(ans, curr);
}
return ans;
}
};