面试算法-130-乘积小于 K 的子数组

题目

给定一个正整数数组 nums和整数 k ,请找出该数组内乘积小于 k 的连续的子数组的个数。

示例 1:

输入: nums = [10,5,2,6], k = 100

输出: 8

解释: 8 个乘积小于 100 的子数组分别为: [10], [5], [2], [6], [10,5], [5,2], [2,6], [5,2,6]。

需要注意的是 [10,5,2] 并不是乘积小于100的子数组。

题目

java 复制代码
class Solution {
    public int numSubarrayProductLessThanK(int[] nums, int k) {
        int n = nums.length;
        int left = 0;
        int right = 0;
        int mul = 1;
        int count = 0;
        while (left <= right && right < n) {
            mul *= nums[right++];
            while (left <= right && mul >= k) {
                mul /= nums[left++];
            }
            if (left < right) {
                count += right - left;
            }
        }
        return count;
    }
}
相关推荐
剪一朵云爱着2 小时前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
报错小能手5 小时前
刷题日常 5 二叉树最大深度
算法
CodeLongBear5 小时前
MySQL索引篇 -- 从数据页的角度看B+树
mysql·面试
码银5 小时前
【数据结构】顺序表
java·开发语言·数据结构
Greedy Alg5 小时前
LeetCode 84. 柱状图中最大的矩形(困难)
算法
im_AMBER5 小时前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油5 小时前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展
包饭厅咸鱼6 小时前
PaddleOCR----制作数据集,模型训练,验证 QT部署(未完成)
算法
无敌最俊朗@6 小时前
C++ 并发与同步速查笔记(整理版)
开发语言·c++·算法