- Leetcode Maximum Product Subarray id:: 64261f45-6885-422c-808c-9344273af1d4 collapsed:: true - Times: - Completion time: 08:38 - Revisions: - Tags: - Algorithms: #Kadane_s_algorithm - Data structures: #array - Difficulty: #difficulty_easy - Platforms: #leetcode - Links: - [link to the problem](https://leetcode.com/problems/maximum-product-subarray/description/) - Problem: - Given an integer array `nums`, find a subarray that has the largest product, and return _the product_. The test cases are generated so that the answer will fit in a **32-bit** integer. - Examples: - ``` Example 1: Input: nums = [2,3,-2,4] Output: 6 Explanation: [2,3] has the largest product 6. Example 2: Input: nums = [-2,0,-1] Output: 0 Explanation: The result cannot be 2, because [-2,-1] is not a subarray. ``` - Constraints: - `1 <= nums.length <= 2 * 104` - `-10 <= nums[i] <= 10` - The product of any prefix or suffix of `nums` is **guaranteed** to fit in a **32-bit** integer. - Thoughts: - This is a variation of Kadane's algorithm: - We don't change the `localMax` variable based on the value, but we only change it to 1 when it's 0, this is because multiplying a integer always give you a bigger abs. value. - We want to have even number of negative numbers multiplied, when there are odd, one additional negative number must be avoided, to solve this problem, we iterate the array twice, from left to right and from right to left. - Solution: - ```java class Solution { public int maxProduct(int[] nums) { // try kadane's algorithm int max = 1; int globalMax = Integer.MIN_VALUE; int globalMax1 = Integer.MIN_VALUE; for (int i : nums) { max *= i; globalMax = Math.max(max, globalMax); if (max == 0) { max = 1; } } max = 1; for (int i = nums.length - 1; i >= 0; i--) { max *= nums[i]; globalMax1 = Math.max(max, globalMax1); if (max ==0) { max = 1; } } return Math.max(globalMax, globalMax1); } } ``` - - TODO: - DONE 写一个 12 bar blues 音乐 SCHEDULED: <2023-04-03 Mon>