LeetCode 713 乘积小于K的子数组[双指针 滑动窗口] HERODING的LeetCode之路

LeetCode 713 乘积小于K的子数组[双指针 滑动窗口] HERODING的LeetCode之路,第1张


解题思路:
一道典型的滑动窗口题型,每次控制窗口内满足乘积小于k,每往前进一次就要加上子集的个数,注意不能重复,所以每次加上r-l+1,就不会重复加了,代码如下:

class Solution {
public:
    int numSubarrayProductLessThanK(vector<int>& nums, int k) {
        if(k == 0 || k == 1) return 0;
        int n = nums.size();
        int l = 0, r = 0, mul = 1;
        int res = 0;
        while(r < n) {
            mul *= nums[r];
            while(mul >= k) {
                mul /= nums[l ++];
            }
            res += r - l + 1;
            r ++;
        }
        return res;
    }
};

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/871659.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存