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)
41 0
|
4月前
|
力扣(LeetCode)数据结构练习题
力扣(LeetCode)数据结构练习题
77 0
|
6月前
|
【Leetcode刷题Python】子数组查找
一个用于寻找给定字符串中最长重复子串的Python函数实现,采用了滑动窗口的方法来检测重复的子串。
30 1
|
6月前
|
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
LeetCode初级算法题:子数组最大平均数+二叉树的最小深度+最长连续递增序列+柠檬水找零
59 0
|
5月前
|
Go
Golang语言之管道channel快速入门篇
这篇文章是关于Go语言中管道(channel)的快速入门教程,涵盖了管道的基本使用、有缓冲和无缓冲管道的区别、管道的关闭、遍历、协程和管道的协同工作、单向通道的使用以及select多路复用的详细案例和解释。
186 4
Golang语言之管道channel快速入门篇
|
5月前
|
Go
Golang语言文件操作快速入门篇
这篇文章是关于Go语言文件操作快速入门的教程,涵盖了文件的读取、写入、复制操作以及使用标准库中的ioutil、bufio、os等包进行文件操作的详细案例。
93 4
Golang语言文件操作快速入门篇
|
5月前
|
Go
Golang语言之gRPC程序设计示例
这篇文章是关于Golang语言使用gRPC进行程序设计的详细教程,涵盖了RPC协议的介绍、gRPC环境的搭建、Protocol Buffers的使用、gRPC服务的编写和通信示例。
155 3
Golang语言之gRPC程序设计示例
|
5月前
|
Golang语言goroutine协程并发安全及锁机制
这篇文章是关于Go语言中多协程操作同一数据问题、互斥锁Mutex和读写互斥锁RWMutex的详细介绍及使用案例,涵盖了如何使用这些同步原语来解决并发访问共享资源时的数据安全问题。
119 4
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等