golang力扣leetcode 713.乘积小于K的子数组

简介: golang力扣leetcode 713.乘积小于K的子数组

713.乘积小于K的子数组

713.乘积小于K的子数组

题解

题目:求乘积小于K的连续的子数组的个数

思路:

1.因为是连续的,所以可以用滑动窗口来做
2.如果当前这个数小于K,说明至少可以加1
3.如果乘积大于等于k,移动左指针,并缩小乘积
4.最后乘积必定小于k,那么ans+=right-left是什么意思呢?
5.[2,5,6],100   对于这种情况,答案有[6][2,5,6],[5,6]
6.其中[6]已经加过了,那么还剩两个,right-left=2

代码

func numSubarrayProductLessThanK(nums []int, k int) int {
  left, right := 0, 0
  ans, cnt := 0, 1
  for right < len(nums) {
    cnt *= nums[right]
    if nums[right] < k {
      ans++
    }
    for cnt >= k && left < right {
      cnt /= nums[left]
      left++
    }
    ans += right - left
    right++
  }
  return ans
}
目录
打赏
0
0
0
0
9
分享
相关文章
【C语言】LeetCode(力扣)上经典题目
【C语言】LeetCode(力扣)上经典题目
|
4月前
|
力扣(LeetCode)数据结构练习题(3)------链表
力扣(LeetCode)数据结构练习题(3)------链表
124 0
|
4月前
力扣(LeetCode)数据结构练习题(2)
力扣(LeetCode)数据结构练习题(2)
40 0
|
4月前
|
力扣(LeetCode)数据结构练习题
力扣(LeetCode)数据结构练习题
77 0
|
6月前
|
【Leetcode刷题Python】子数组查找
一个用于寻找给定字符串中最长重复子串的Python函数实现,采用了滑动窗口的方法来检测重复的子串。
30 1
|
6月前
|
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
59 0
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
LeetCode初级算法题:寻找数组的中心索引+x的平方根+三个数的最大乘积+Leetcode 149:直线上最多的点数 Java详解
57 0
|
6月前
|
【Leetcode刷题Python】318. 最大单词长度乘积
本文提供了LeetCode题目318的Python编程解决方案,题目要求在一个字符串数组中找出两个不含有公共字母的单词,且这两个单词的长度乘积最大,如果不存在这样的两个单词,则返回0。
30 0
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
|
7月前
2670.找出不同元素数目差数组-力扣(LeetCode)
2670.找出不同元素数目差数组-力扣(LeetCode)
56 0