LeetCode-713:Subarray Product Less Than K (乘积小于K的子数组个数) -- medium
2017-11-10 10:41
134 查看
Question
Your are given an array of positive integers nums.Count and print the number of (contiguous) subarrays where the product of all the elements in the subarray is less than k.
Example 1:
Input: nums = [10, 5, 2, 6], k = 100
Output: 8
Explanation: The 8 subarrays that have product less than 100 are: [10], [5], [2], [6], [10, 5], [5, 2], [2, 6], [5, 2, 6].
Note that [10, 5, 2] is not included as the product of 100 is not strictly less than k.
Note:
0 < nums.length <= 50000.
0 < nums[i] < 1000.
0 <= k < 10^6.
问题解析:
给定数组,和整数K,计数数组中所有满足元素乘积小于K的连续子数组的个数。
Answer
Solution 1:
双指针遍历。该题目主要的解题思路是寻找每步相同的计数规律。
按照一般的思维,要想记录连续子数组需要从左向右遍历数组。
这里最重要的就是处理乘积大于K的情况,需要丢弃最前面的元素,那么说明需要有一个指针记录最前面元素的位置。
在不大于K的情况下,则累加每次加入新元素后子数组的个数。
class Solution { public int numSubarrayProductLessThanK(int[] nums, int k) { if ( k <= 1) return 0; int n = nums.length; long p = 1l; int i = 0, total = 0; for (int j = 0; j < n; j++){ p *= nums[j]; while (p >= k){ p /= nums[i]; i++; } total += (j - i + 1); } return total; } }
时间复杂度:O(n),空间复杂度:O(1)
相关文章推荐
- [LeetCode] Subarray Product Less Than K 子数组乘积小于K
- leetcode 713. Subarray Product Less Than K 连续子数组之积小于K + 移动窗口
- LeetCode-152:Maximum Product Subarray (乘积最大连续子数组) -- medium
- LeetCode:152_Maximum Product Subarray | 最大乘积连续子数组 | Medium
- leetcode 713 Subarray Product Less Than K
- LeetCode:152_Maximum Product Subarray | 最大乘积连续子数组 | Medium
- [LeetCode] 152. Maximum Product Subarray 求最大子数组乘积
- 【LeetCode】Maximum Product Subarray 求连续子数组使其乘积最大
- leetcode 713. Subarray Product Less Than K
- 【LeetCode-面试算法经典-Java实现】【152-Maximum Product Subarray(子数组的最大乘积)】
- 713. Subarray Product Less Than K
- leetcode_Maximum Product Subarray _medium(最大子数组之积)
- LeetCode 152. Maximum Product Subarray--连续子数组最大乘积
- LeetCode Maximum Product Subarray(最大子数组乘积)
- [LeetCode] Maximum Product Subarray 求最大子数组乘积
- leetcode152-Maximum Product Subarray(乘积最大子数组)
- Leetcode 152 Maximum Product Subarray 子数组最大乘积
- LeetCode Subarray Product Less Than K
- LeetCode:152. Maximum Product Subarray Java 子数组最大乘积
- [LeetCode] Maximum Product Subarray 求最大子数组乘积