-
Notifications
You must be signed in to change notification settings - Fork 155
/
Copy pathcontainer-with-most-water.js
73 lines (68 loc) · 2 KB
/
container-with-most-water.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
/**
* Container With Most Water
*
* Given n non-negative integers a1, a2, ..., an , where each represents a point at coordinate (i, ai).
* n vertical lines are drawn such that the two endpoints of line i is at (i, ai) and (i, 0). Find two lines,
* which together with x-axis forms a container, such that the container contains the most water.
*
* Note: You may not slant the container and n is at least 2.
*
* Here's another way to see what happens in a matrix representation:
*
* Draw a matrix where the row is the first line, and the column is the second line. For example, say n=6.
*
* In the figures below, x means we don't need to compute the volume for that case: (1) On the diagonal,
* the two lines are overlapped; (2) The lower left triangle area of the matrix is symmetric to the upper
* right area.
*
* We start by computing the volume at (1,6), denoted by o. Now if the left line is shorter than the right
* line, then all the elements left to (1,6) on the first row have smaller volume, so we don't need to compute
* those cases (crossed by ---).
*
* 1 2 3 4 5 6
* 1 x ------- o
* 2 x x
* 3 x x x
* 4 x x x x
* 5 x x x x x
* 6 x x x x x x
*
* Next we move the left line and compute (2,6). Now if the right line is shorter, all cases below (2,6) are eliminated.
*
* 1 2 3 4 5 6
* 1 x ------- o
* 2 x x o
* 3 x x x |
* 4 x x x x |
* 5 x x x x x |
* 6 x x x x x x
*
* And no matter how this o path goes, we end up only need to find the max value on this path, which contains n-1 cases.
*
* 1 2 3 4 5 6
* 1 x ------- o
* 2 x x - o o o
* 3 x x x o | |
* 4 x x x x | |
* 5 x x x x x |
* 6 x x x x x x
*/
/**
* @param {number[]} height
* @return {number}
*/
const maxArea = height => {
const n = height.length;
let max = 0;
for (let i = 0, j = n - 1; i < j; ) {
const area = Math.min(height[i], height[j]) * (j - i);
max = Math.max(max, area);
if (height[i] < height[j]) {
i++;
} else {
j--;
}
}
return max;
};
export { maxArea };