Description
You are given an integer array nums
and two integers minK
and maxK
.
A fixed-bound subarray of nums
is a subarray that satisfies the following conditions:
- The minimum value in the subarray is equal to
minK
. - The maximum value in the subarray is equal to
maxK
.
Return the number of fixed-bound subarrays.
A subarray is a contiguous part of an array.
Example 1:
Input: nums = [1,3,5,2,7,5], minK = 1, maxK = 5 Output: 2 Explanation: The fixed-bound subarrays are [1,3,5] and [1,3,5,2].
Example 2:
Input: nums = [1,1,1,1], minK = 1, maxK = 1 Output: 10 Explanation: Every subarray of nums is a fixed-bound subarray. There are 10 possible subarrays.
Constraints:
2 <= nums.length <= 105
1 <= nums[i], minK, maxK <= 106
Code
一開始我覺得這題和 Longest Continuous Subarray With Absolute Diff Less Than or Equal to Limit 很像。
後來看了解答發現不需要這麼麻煩,只需要單純的 two pointer 就行了。
1. start , minFound ... maxFound
2. start , maxFound ... minFound
3. start ..., ..... min/max Found
1.2. 兩種情況的 subarray 個數都是 + 1,而 3. 代表 min max 重疊的狀況,例如 1111,因此要用 min(minFound, maxFound) - start 來計算。
Time Complexity: , Space Complexity: