|
1 | | -// Time complexity: O(n^2) |
| 1 | +// Time complexity: O(n) |
2 | 2 | // Space complexity: O(n) |
3 | 3 |
|
4 | 4 | /** |
|
7 | 7 | */ |
8 | 8 | var maxProduct = function (nums) { |
9 | 9 | let answer = nums[0]; |
| 10 | + const products = Array.from({ length: nums.length + 1 }, () => null); |
| 11 | + products[0] = [1, 1]; // [min, max] |
10 | 12 |
|
11 | | - const productGroups = [[]]; |
| 13 | + for (let i = 1; i < products.length; i++) { |
| 14 | + const cases = []; |
12 | 15 |
|
13 | | - for (let i = 0; i < nums.length; i++) { |
14 | | - const productGroup = productGroups.at(-1); |
| 16 | + // case 1 |
| 17 | + cases.push(nums[i - 1]); |
15 | 18 |
|
16 | | - if (nums[i] === 0) { |
17 | | - productGroups.push([]); |
18 | | - } |
| 19 | + // case 2 |
| 20 | + cases.push(nums[i - 1] * products[i - 1][0]); |
19 | 21 |
|
20 | | - if (productGroup.length === 0) { |
21 | | - productGroup.push(nums[i]); |
22 | | - continue; |
23 | | - } |
| 22 | + // case 3 |
| 23 | + cases.push(nums[i - 1] * products[i - 1][1]); |
24 | 24 |
|
25 | | - productGroup.push(nums[i] * productGroup.at(-1)); |
26 | | - } |
27 | | - |
28 | | - for (const group of productGroups) { |
29 | | - for (let i = 0; i < group.length; i++) { |
30 | | - answer = Math.max(answer, group[i]); |
31 | | - |
32 | | - for (let j = 0; j < i; j++) { |
33 | | - answer = Math.max(answer, group[i] / group[j]); |
34 | | - } |
35 | | - } |
| 25 | + const product = [Math.min(...cases), Math.max(...cases)]; |
| 26 | + products[i] = product; |
| 27 | + answer = Math.max(answer, product[1]); |
36 | 28 | } |
37 | 29 |
|
38 | 30 | return answer; |
|
0 commit comments