Premium Only Content

2762. Continuous Subarrays
You are given a 0-indexed integer array nums. A subarray of nums is called continuous if:
Let i, i + 1, ..., j be the indices in the subarray. Then, for each pair of indices i <= i1, i2 <= j, 0 <= |nums[i1] - nums[i2]| <= 2.
Return the total number of continuous subarrays.
A subarray is a contiguous non-empty sequence of elements within an array.
Example 1:
Input: nums = [5,4,2,4]
Output: 8
Explanation:
Continuous subarray of size 1: [5], [4], [2], [4].
Continuous subarray of size 2: [5,4], [4,2], [2,4].
Continuous subarray of size 3: [4,2,4].
Thereare no subarrys of size 4.
Total continuous subarrays = 4 + 3 + 1 = 8.
It can be shown that there are no more continuous subarrays.
Example 2:
Input: nums = [1,2,3]
Output: 6
Explanation:
Continuous subarray of size 1: [1], [2], [3].
Continuous subarray of size 2: [1,2], [2,3].
Continuous subarray of size 3: [1,2,3].
Total continuous subarrays = 3 + 2 + 1 = 6.
Constraints:
1 <= nums.length <= 105
1 <= nums[i] <= 109
class Solution {
public:
long long continuousSubarrays(vector<int>& nums) {
long ans = 1; // [nums[0]]
int left = nums[0] - 2;
int right = nums[0] + 2;
int l = 0;
// nums[l..r] is a valid window with range in [left, right].
for (int r = 1; r < nums.size(); r++) {
if (left <= nums[r] && nums[r] <= right) {
left = max(left, nums[r] - 2);
right = min(right, nums[r] + 2);
} else {
// nums[r] is out-of-bounds, so reconstruct the window.
left = nums[r] - 2;
right = nums[r] + 2;
l = r;
// If we consistently move leftward in each iteration, it implies that
// the entire left subarray satisfies the given condition. For every
// subarray with l in the range [0, r], the condition is met, preventing
// the code from reaching the final "else" condition. Instead, it stops
// at the "if" condition.
while (nums[r] - 2 <= nums[l] && nums[l] <= nums[r] + 2) {
left = max(left, nums[l] - 2);
right = min(right, nums[l] + 2);
--l;
}
++l;
}
// nums[l..r], nums[l + 1..r], ..., nums[r]
ans += r - l + 1;
}
return ans;
}
};
-
1:02:50
Flyover Conservatives
9 hours agoEric Trump: America’s Most Subpoenaed Man SPEAKS OUT! | FOC Show
20.8K5 -
LIVE
PandaSub2000
1 day agoLIVE 10/3 @10pm ET | SUPER MARIO GALAXY 1 & 2 on SWITCH 2
235 watching -
1:26:04
Glenn Greenwald
8 hours agoJournalist Ken Klippenstein on Trump's New Domestic Terrorism Memo; Glenn Takes Your Questions on Bari Weiss's CBS Role, His Interview with Nick Fuentes, and More | SYSTEM UPDATE #526
75.8K59 -
SynthTrax & DJ Cheezus Livestreams
2 days agoFriday Night Synthwave 80s 90s Electronica and more DJ MIX Livestream GOTH NIGHT Special Edition
27.1K2 -
2:20:47
Mally_Mouse
5 days agoFriend Friday!! 🎉 - Let's Play! - Lockdown Protocol
29.5K1 -
LIVE
MissesMaam
4 hours ago*Spicy* Friend Friday LOCKDOWN Protocol!!! :: SpookTober 💚✨
201 watching -
41:36
MattMorseTV
5 hours ago $0.80 earned🔴Portland just made a BIG MISTAKE.🔴
43.6K73 -
13:10:23
LFA TV
1 day agoLIVE & BREAKING NEWS! | FRIDAY 10/3/25
165K46 -
4:07:27
Nerdrotic
9 hours ago $0.33 earnedHollywood is TARIFFied, James Gunn Attacks Fans, Bill Burqa, RoP is Doomed | Friday Night Tights 374
76.1K12 -
LIVE
Eternal_Spartan
13 hours ago🟢 Eternal Spartan Plays Destiny 2 | The Best PVP/PVE Action!| USMC Veteran
38 watching