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

Posted HERODING23

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 713 乘积小于K的子数组[双指针 滑动窗口] HERODING的LeetCode之路相关的知识,希望对你有一定的参考价值。


解题思路:
一道典型的滑动窗口题型,每次控制窗口内满足乘积小于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;
    
;

以上是关于LeetCode 713 乘积小于K的子数组[双指针 滑动窗口] HERODING的LeetCode之路的主要内容,如果未能解决你的问题,请参考以下文章

leetcode-713 乘积小于k的数组

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

⭐算法入门⭐《双指针》中等04 —— LeetCode 713. 乘积小于K的子数组

713. 乘积小于K的子数组

LeetCode 937. 重新排列日志文件 / 1823. 找出游戏的获胜者(约瑟夫环问题) / 713. 乘积小于 K 的子数组

数组713. 乘积小于K的子数组