class Solution {
public int numSubarrayProductLessThanK(int[] nums, int k) {
if(k < 2) return 0;
int i = 0,j = 0;
int ans = 0;
int x = 1;
while(j < nums.length){
x *= nums[j];
//当l=r时就为1了,是小于k的不会越界,此时j-i+1也为0
while(x >= k) x /= nums[i++];
//此时保证了x是小于k的,相当于求右边界左边界为l,右边界为r的连续子数组的个数,
//右边界是不断递增的,又因为是连续,所以满足条件的每种长度的子数组只会有一个
//且右边界一直在变也就是不会重复
ans += j-i+1;
j++;
}
return ans;
}
}
相关文章
- 10-13剑指 Offer 40. 最小的k个数(简单)
- 10-13LeetCode 剑指 Offer II 069. 山峰数组的顶部(三分) / 38. 外观数列 / 282. 给表达式添加运算符
- 10-13剑指offer-面试题63-股票的最大利润-数组
- 10-13[剑指OFFER] 数组中的逆序对
- 10-13剑指offer-数组中的逆序对-数组-python
- 10-13剑指offer_数组中的逆序对
- 10-13剑指Offer——数组中的逆序对
- 10-13《剑指Offer——不修改数组找出重复的数字》代码
- 10-13剑指 Offer 11. 旋转数组的最小数字
- 10-13剑指 Offer 11. 旋转数组的最小数字