[M双指针] lc713. 乘积小于 K 的子数组(双指针+好题)

文章目录

    • [1. 题目来源](#1. 题目来源)
    • [2. 题目解析](#2. 题目解析)

1. 题目来源

链接:713. 乘积小于 K 的子数组

题单位置:

    1. 滑动窗口(定长/不定长/多指针)
    • 不定长滑动窗口(求子数组个数)

2. 题目解析

经典的 双指针、滑动窗口 问题。

思路:

  • 能发现让右边界向右拓展时,窗口内元素已经大于 k,则可以尝试缩小左边界。
  • 且左边界不会再回头向左拓展,左指针具有单调性。适合使用滑动窗口来处理。

技巧:

  • 灵神这里写了些特殊判断,k=0、1,然后就可以在 while 循环中不用去判断 l<=r 的这个情况。反例就是 [1,1,1], k=1 这种情况。
  • 个人觉得还是判断一下比较好。更加直观。
  • 有些判断可加可不加,把握好就行。

  • 时间复杂度 : O ( n ) O(n) O(n)
  • 空间复杂度 : O ( 1 ) O(1) O(1)

cpp 复制代码
class Solution {
public:
    int numSubarrayProductLessThanK(vector<int>& nums, int k) {
        int n = nums.size();
        int res = 0, s = 1;
        for (int l = 0, r = 0; r < n; r ++ ) {
            s *= nums[r];
            while (l <= r && s >= k) s /= nums[l ++ ]; // 这样写,l 最终可能会越界,超过 r
            res += r - l + 1;
        }
        
        return res;
    }
};
相关推荐
阿维的博客日记14 小时前
简单说一下ArrayList的add机制,适合应试者表达的
算法·arraylist
阿Y加油吧14 小时前
两道位运算 / 摩尔投票经典题复盘:只出现一次的数字 & 多数元素
数据结构·算法·leetcode
Evand J15 小时前
【课题推荐】三模型IMM交互式多模型滤波算法,匀速/左转/右转目标跟踪,附MATLAB代码测试结果
算法·matlab·目标跟踪·无人机·imm·多模型
05候补工程师15 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵
青山师15 小时前
HashMap深度解析:哈希冲突、扩容机制与线程安全
算法·安全·哈希算法·java面试·hashmap源码
货拉拉技术15 小时前
私域转化率翻倍的秘密:我们把多模态Agent融进了私域营销
人工智能·算法·设计模式
WL_Aurora16 小时前
备战蓝桥杯国赛【Day 17】
算法·蓝桥杯
kcuwu.16 小时前
决策树与集成学习深度解析:从原理到实践
算法·决策树·集成学习
programhelp_16 小时前
2026 Fall Coinbase Software Engineer OA 真题分享与通关指南
算法
炘爚16 小时前
数据结构:顺序表
数据结构