面试算法-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;
    }
}
相关推荐
有意义9 分钟前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户726876103372 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect2 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
我叫黑大帅2 小时前
Go 语言中处理「未知类型数据」的两大核心手段
后端·面试·go
拉不动的猪3 小时前
重温Vue异步更新队列
前端·javascript·面试
韭菜炒大葱18 小时前
前端经典面试题:从 URL 输入到页面展示,中间经历了什么?
前端·http·面试
kevinzeng19 小时前
反射的初步理解
后端·面试
swipe19 小时前
纯函数、柯里化与函数组合:从原理到源码,构建更可维护的前端代码体系
前端·javascript·面试
Lee川19 小时前
JavaScript 中的 `this` 与变量查找:一场关于“身份”与“作用域”的深度博弈
前端·javascript·面试
前端拿破轮21 小时前
从0到1搭建个人网站(三):用 Cloudflare R2 + PicGo 搭建高速图床
前端·后端·面试