-
Notifications
You must be signed in to change notification settings - Fork 8
Expand file tree
/
Copy path312-Burst-Balloons.js
More file actions
33 lines (28 loc) · 863 Bytes
/
312-Burst-Balloons.js
File metadata and controls
33 lines (28 loc) · 863 Bytes
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
/**
* @param {number[]} nums
* @return {number}
*/
const maxCoins = (nums) => {
const n = nums.length;
if (n === 0) return 0;
if (n === 1) return nums[0];
if (n === 2) return nums[0] * nums[1] + Math.max(nums[1], nums[0]);
nums = [1, ...nums, 1];
const result = [];
// eslint-disable-next-line no-unused-vars
for (const _ of nums) {
const arr = new Array(nums.length).fill(0);
result.push(arr);
}
for (let l = 1; l < n + 1; l++) {
for (let i = 1; i < n - l + 2; i++) {
const j = i + l - 1;
for (let k = i; k < j + 1; k++) {
const temp =
nums[i - 1] * nums[k] * nums[j + 1] + result[i][k - 1] + result[k + 1][j];
result[i][j] = Math.max(temp, result[i][j]);
}
}
}
return result[1][n];
};