|
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