面试算法-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;
    }
}
相关推荐
Wang2012201316 小时前
LSTM和Transformer对比
人工智能·算法·架构
9号达人16 小时前
支付配置时好时坏?异步方法里的对象引用坑
java·后端·面试
KingRumn16 小时前
Linux进程间通信之D-Bus
linux·算法
fufu031116 小时前
Linux环境下的C语言编程(四十九)
linux·c语言·算法
YGGP16 小时前
【Golang】LeetCode198. 打家劫舍
算法·leetcode
啊阿狸不会拉杆16 小时前
《数字图像处理》实验6-图像分割方法
图像处理·人工智能·算法·计算机视觉·数字图像处理
YGGP16 小时前
【Golang】LeetCode 152. 乘积最大子数组
算法·leetcode
爱学大树锯16 小时前
171 · 乱序字符串
算法
报错小能手17 小时前
数据结构 哈希表(链地址法)
数据结构·哈希算法·散列表
小李小李快乐不已17 小时前
栈和堆理论基础
c++·算法·leetcode