LeetCode-795区间子数组个数

Posted tmpUser

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode-795区间子数组个数相关的知识,希望对你有一定的参考价值。

问题

给定一个元素都是正整数的数组A ,正整数 L 以及 R (L <= R)。

求连续、非空且其中最大元素满足大于等于L 小于等于R的子数组个数。

示例

输入:
A = [2, 1, 4, 3]
L = 2
R = 3
输出: 3
解释: 满足条件的子数组: [2], [2, 1], [3].

解答

class Solution {
public:
    int numSubarrayBoundedMax(vector<int>& nums, int left, int right) {
        return atMost(nums, right) - atMost(nums, left - 1);
    }
private:
    int atMost(vector<int>& nums, int k) {
        int res = 0, cnt = 0;
        for (int i = 0; i < nums.size(); i++) {
            if (nums[i] <= k) cnt++;
            else cnt = 0;
            res += cnt; // 每次都会添加以nums[i]结尾的满足条件的子数组数量
        }
        return res;
    }
};

重点思路

atMost函数求解的是最大值不超过k的子数组个数。时间复杂度\\(O(N)\\)

以上是关于LeetCode-795区间子数组个数的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 0795. 区间子数组个数

LeetCode 0795. 区间子数组个数

795. 区间子数组个数

HDU4622:Reincarnation(后缀数组,求区间内不同子串的个数)

实现数组中连续子数组值和最大

HDU 4622 Reincarnation (区间不相同子串个数:字符串哈希 | 后缀数组 | 后缀自动机)