剑指offer 乘积小于K的子数组
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;
}
}
本文来自博客园,作者:蹇爱黄,转载请注明原文链接:https://www.cnblogs.com/jianjiana/p/15863263.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏
· Manus爆火,是硬核还是营销?