A game for one player is played on a board consisting of N consecutive squares, numbered from 0 to N − 1. There is a number written on each square. A non-empty array A of N integers contains the numbers written on the squares. Moreover, some squares can be marked during the game.
At the beginning of the game, there is a pebble on square number 0 and this is the only square on the board which is marked. The goal of the game is to move the pebble to square number N − 1.
During each turn we throw a six-sided die, with numbers from 1 to 6 on its faces, and consider the number K, which shows on the upper face after the die comes to rest. Then we move the pebble standing on square number I to square number I + K, providing that square number I + K exists. If square number I + K does not exist, we throw the die again until we obtain a valid move. Finally, we mark square number I + K.
After the game finishes (when the pebble is standing on square number N − 1), we calculate the result. The result of the game is the sum of the numbers written on all marked squares.
For example, given the following array:
A[0] = 1 A[1] = -2 A[2] = 0 A[3] = 9 A[4] = -1 A[5] = -2one possible game could be as follows:
- the pebble is on square number 0, which is marked;
- we throw 3; the pebble moves from square number 0 to square number 3; we mark square number 3;
- we throw 5; the pebble does not move, since there is no square number 8 on the board;
- we throw 2; the pebble moves to square number 5; we mark this square and the game ends.
The marked squares are 0, 3 and 5, so the result of the game is 1 + 9 + (−2) = 8. This is the maximal possible result that can be achieved on this board.
Write a function:
function solution(A);
that, given a non-empty array A of N integers, returns the maximal result that can be achieved on the board represented by array A.
For example, given the array
A[0] = 1 A[1] = -2 A[2] = 0 A[3] = 9 A[4] = -1 A[5] = -2the function should return 8, as explained above.
Write an efficient algorithm for the following assumptions:
- N is an integer within the range [2..100,000];
- each element of array A is an integer within the range [−10,000..10,000].
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => );
for (let i = 0; i < A.length; i++) {
for (let j = 1, j < 6; j++) {
}
}
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = 1, j < 6; j++) {
}
}
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6), j < 6; j++) {
}
}
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6), j < ; j++) {
}
}
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6), j < i; j++) {
result[i] = Math.max(result[i], result[j] + A[i]);
}
}
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6), j < i; j++) {
result[i] = Math.max(result[i], result[j] + A[i]);
}
}
return result[result.length - 1]
}
solution.js:10 for (let j = Math.max(0, i - 6), j < i; j++) { ^ SyntaxError: Unexpected token < at createScript (vm.js:80:10) at Object.runInNewContext (vm.js:135:10) at getSolution (/tmp/exec.js:392:29) at Promise.resolve.then (/tmp/exec.js:426:34) at <anonymous> at process._tickCallback (internal/process/next_tick.js:188:7) at Function.Module.runMain (module.js:686:11) at startup (bootstrap_node.js:187:16) at bootstrap_node.js:608:3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6); j < i; j++) {
result[i] = Math.max(result[i], result[j] + A[i]);
}
}
return result[result.length - 1]
}
ReferenceError: result is not defined at solution (solution.js:11:13) at solutionWrapper (/tmp/exec.js:402:28) at Promise.resolve.then (/tmp/exec.js:428:24) at <anonymous> at process._tickCallback (internal/process/next_tick.js:188:7) at Function.Module.runMain (module.js:686:11) at startup (bootstrap_node.js:187:16) at bootstrap_node.js:608:3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6); j < i; j++) {
dp[i] = Math.max(result[i], result[j] + A[i]);
}
}
return result[result.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = Math.max(0, i - 6); j < i; j++) {
dp[i] = Math.max(dp[i], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i; j < i; j++) {
dp[i] = Math.max(dp[i], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i; j < i +; j++) {
dp[i] = Math.max(dp[i], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i; j < i + 6; j++) {
dp[i] = Math.max(dp[i], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i; j < i + 6; j++) {
dp[j] = Math.max(dp[i], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6; j++) {
dp[j] = Math.max(dp[j], dp[j] + A[i]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
Invalid result type, integer expected, non-integer number found
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 ; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, -1, 1]
function result: 1
function result: 15
function result: 1
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
function result: 1
function result: 15
function result: 1
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
function result: 1
function result: 15
function result: 1
function result: -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
co
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, ')
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:')
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
-> i, j, dpi, aj, dpj: 0 1 1 -2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 0 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 9 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -2 -Infinity -> i, j, dpi, aj, dpj: 1 2 -1 0 1 -> i, j, dpi, aj, dpj: 1 3 -1 9 10 -> i, j, dpi, aj, dpj: 1 4 -1 -1 0 -> i, j, dpi, aj, dpj: 1 5 -1 -2 -1 -> i, j, dpi, aj, dpj: 2 3 1 9 10 -> i, j, dpi, aj, dpj: 2 4 1 -1 0 -> i, j, dpi, aj, dpj: 2 5 1 -2 -1 -> i, j, dpi, aj, dpj: 3 4 10 -1 0 -> i, j, dpi, aj, dpj: 3 5 10 -2 -1 -> i, j, dpi, aj, dpj: 4 5 9 -2 8
function result: 1
function result: 15
-> i, j, dpi, aj, dpj: 0 1 1 2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 3 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 4 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 5 -Infinity -> i, j, dpi, aj, dpj: 1 2 3 3 4 -> i, j, dpi, aj, dpj: 1 3 3 4 5 -> i, j, dpi, aj, dpj: 1 4 3 5 6 -> i, j, dpi, aj, dpj: 2 3 6 4 7 -> i, j, dpi, aj, dpj: 2 4 6 5 8 -> i, j, dpi, aj, dpj: 3 4 10 5 11
function result: 1
-> i, j, dpi, aj, dpj: 0 1 1 -10 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -9 -1 0 -> i, j, dpi, aj, dpj: 1 3 -9 -1 0 -> i, j, dpi, aj, dpj: 1 4 -9 -1 0 -> i, j, dpi, aj, dpj: 1 5 -9 -1 0 -> i, j, dpi, aj, dpj: 1 6 -9 1 -Infinity -> i, j, dpi, aj, dpj: 2 3 0 -1 0 -> i, j, dpi, aj, dpj: 2 4 0 -1 0 -> i, j, dpi, aj, dpj: 2 5 0 -1 0 -> i, j, dpi, aj, dpj: 2 6 0 1 -8 -> i, j, dpi, aj, dpj: 3 4 0 -1 0 -> i, j, dpi, aj, dpj: 3 5 0 -1 0 -> i, j, dpi, aj, dpj: 3 6 0 1 1 -> i, j, dpi, aj, dpj: 4 5 0 -1 0 -> i, j, dpi, aj, dpj: 4 6 0 1 1 -> i, j, dpi, aj, dpj: 5 6 0 1 1
function result: -3
-> i, j, dpi, aj, dpj: 0 1 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 2 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 6 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 2 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 2 7 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 3 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 8 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 4 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 4 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 9 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 5 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 9 -2 -1 -3 -> i, j, dpi, aj, dpj: 6 7 -3 -1 -3 -> i, j, dpi, aj, dpj: 6 8 -3 -1 -3 -> i, j, dpi, aj, dpj: 6 9 -3 -1 -3 -> i, j, dpi, aj, dpj: 7 8 -3 -1 -3 -> i, j, dpi, aj, dpj: 7 9 -3 -1 -3 -> i, j, dpi, aj, dpj: 8 9 -3 -1 -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 1; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 1; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
Invalid result type, integer expected, non-integer number foundstdout:
-> i, j, dpi, aj, dpj: 1 2 -Infinity 0 -Infinity -> i, j, dpi, aj, dpj: 1 3 -Infinity 9 -Infinity -> i, j, dpi, aj, dpj: 1 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 5 -Infinity -2 -Infinity -> i, j, dpi, aj, dpj: 2 3 -Infinity 9 -Infinity -> i, j, dpi, aj, dpj: 2 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 5 -Infinity -2 -Infinity -> i, j, dpi, aj, dpj: 3 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 5 -Infinity -2 -Infinity -> i, j, dpi, aj, dpj: 4 5 -Infinity -2 -Infinity
function result: 1
Invalid result type, integer expected, non-integer number foundstdout:
-> i, j, dpi, aj, dpj: 1 2 -Infinity 3 -Infinity -> i, j, dpi, aj, dpj: 1 3 -Infinity 4 -Infinity -> i, j, dpi, aj, dpj: 1 4 -Infinity 5 -Infinity -> i, j, dpi, aj, dpj: 2 3 -Infinity 4 -Infinity -> i, j, dpi, aj, dpj: 2 4 -Infinity 5 -Infinity -> i, j, dpi, aj, dpj: 3 4 -Infinity 5 -Infinity
Invalid result type, integer expected, non-integer number foundstdout:
-> i, j, dpi, aj, dpj: 1 2 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 3 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 6 -Infinity 1 -Infinity -> i, j, dpi, aj, dpj: 2 3 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 6 -Infinity 1 -Infinity -> i, j, dpi, aj, dpj: 3 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 6 -Infinity 1 -Infinity -> i, j, dpi, aj, dpj: 4 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 6 -Infinity 1 -Infinity -> i, j, dpi, aj, dpj: 5 6 -Infinity 1 -Infinity
Invalid result type, integer expected, non-integer number foundstdout:
-> i, j, dpi, aj, dpj: 1 2 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 3 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 1 6 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 3 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 6 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 2 7 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 4 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 6 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 7 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 3 8 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 5 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 6 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 7 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 8 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 4 9 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 5 6 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 5 7 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 5 8 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 5 9 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 6 7 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 6 8 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 6 9 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 7 8 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 7 9 -Infinity -1 -Infinity -> i, j, dpi, aj, dpj: 8 9 -Infinity -1 -Infinity
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j < i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
-> i, j, dpi, aj, dpj: 0 1 1 -2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 0 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 9 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -2 -Infinity -> i, j, dpi, aj, dpj: 1 2 -1 0 1 -> i, j, dpi, aj, dpj: 1 3 -1 9 10 -> i, j, dpi, aj, dpj: 1 4 -1 -1 0 -> i, j, dpi, aj, dpj: 1 5 -1 -2 -1 -> i, j, dpi, aj, dpj: 2 3 1 9 10 -> i, j, dpi, aj, dpj: 2 4 1 -1 0 -> i, j, dpi, aj, dpj: 2 5 1 -2 -1 -> i, j, dpi, aj, dpj: 3 4 10 -1 0 -> i, j, dpi, aj, dpj: 3 5 10 -2 -1 -> i, j, dpi, aj, dpj: 4 5 9 -2 8
function result: 1
function result: 15
-> i, j, dpi, aj, dpj: 0 1 1 2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 3 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 4 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 5 -Infinity -> i, j, dpi, aj, dpj: 1 2 3 3 4 -> i, j, dpi, aj, dpj: 1 3 3 4 5 -> i, j, dpi, aj, dpj: 1 4 3 5 6 -> i, j, dpi, aj, dpj: 2 3 6 4 7 -> i, j, dpi, aj, dpj: 2 4 6 5 8 -> i, j, dpi, aj, dpj: 3 4 10 5 11
function result: 1
-> i, j, dpi, aj, dpj: 0 1 1 -10 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -9 -1 0 -> i, j, dpi, aj, dpj: 1 3 -9 -1 0 -> i, j, dpi, aj, dpj: 1 4 -9 -1 0 -> i, j, dpi, aj, dpj: 1 5 -9 -1 0 -> i, j, dpi, aj, dpj: 1 6 -9 1 -Infinity -> i, j, dpi, aj, dpj: 2 3 0 -1 0 -> i, j, dpi, aj, dpj: 2 4 0 -1 0 -> i, j, dpi, aj, dpj: 2 5 0 -1 0 -> i, j, dpi, aj, dpj: 2 6 0 1 -8 -> i, j, dpi, aj, dpj: 3 4 0 -1 0 -> i, j, dpi, aj, dpj: 3 5 0 -1 0 -> i, j, dpi, aj, dpj: 3 6 0 1 1 -> i, j, dpi, aj, dpj: 4 5 0 -1 0 -> i, j, dpi, aj, dpj: 4 6 0 1 1 -> i, j, dpi, aj, dpj: 5 6 0 1 1
function result: -3
-> i, j, dpi, aj, dpj: 0 1 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 2 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 6 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 2 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 2 7 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 3 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 8 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 4 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 4 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 9 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 5 6 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 9 -2 -1 -3 -> i, j, dpi, aj, dpj: 6 7 -3 -1 -3 -> i, j, dpi, aj, dpj: 6 8 -3 -1 -3 -> i, j, dpi, aj, dpj: 6 9 -3 -1 -3 -> i, j, dpi, aj, dpj: 7 8 -3 -1 -3 -> i, j, dpi, aj, dpj: 7 9 -3 -1 -3 -> i, j, dpi, aj, dpj: 8 9 -3 -1 -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
-> i, j, dpi, aj, dpj: 0 1 1 -2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 0 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 9 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -2 -Infinity -> i, j, dpi, aj, dpj: 1 2 -1 0 1 -> i, j, dpi, aj, dpj: 1 3 -1 9 10 -> i, j, dpi, aj, dpj: 1 4 -1 -1 0 -> i, j, dpi, aj, dpj: 1 5 -1 -2 -1 -> i, j, dpi, aj, dpj: 2 3 1 9 10 -> i, j, dpi, aj, dpj: 2 4 1 -1 0 -> i, j, dpi, aj, dpj: 2 5 1 -2 -1 -> i, j, dpi, aj, dpj: 3 4 10 -1 0 -> i, j, dpi, aj, dpj: 3 5 10 -2 -1 -> i, j, dpi, aj, dpj: 4 5 9 -2 8
function result: 1
function result: 15
-> i, j, dpi, aj, dpj: 0 1 1 2 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 3 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 4 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 5 -Infinity -> i, j, dpi, aj, dpj: 1 2 3 3 4 -> i, j, dpi, aj, dpj: 1 3 3 4 5 -> i, j, dpi, aj, dpj: 1 4 3 5 6 -> i, j, dpi, aj, dpj: 2 3 6 4 7 -> i, j, dpi, aj, dpj: 2 4 6 5 8 -> i, j, dpi, aj, dpj: 3 4 10 5 11
function result: 2
-> i, j, dpi, aj, dpj: 0 1 1 -10 -Infinity -> i, j, dpi, aj, dpj: 0 2 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 6 1 1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -9 -1 0 -> i, j, dpi, aj, dpj: 1 3 -9 -1 0 -> i, j, dpi, aj, dpj: 1 4 -9 -1 0 -> i, j, dpi, aj, dpj: 1 5 -9 -1 0 -> i, j, dpi, aj, dpj: 1 6 -9 1 2 -> i, j, dpi, aj, dpj: 2 3 0 -1 0 -> i, j, dpi, aj, dpj: 2 4 0 -1 0 -> i, j, dpi, aj, dpj: 2 5 0 -1 0 -> i, j, dpi, aj, dpj: 2 6 0 1 2 -> i, j, dpi, aj, dpj: 3 4 0 -1 0 -> i, j, dpi, aj, dpj: 3 5 0 -1 0 -> i, j, dpi, aj, dpj: 3 6 0 1 2 -> i, j, dpi, aj, dpj: 4 5 0 -1 0 -> i, j, dpi, aj, dpj: 4 6 0 1 2 -> i, j, dpi, aj, dpj: 5 6 0 1 2
function result: -3
-> i, j, dpi, aj, dpj: 0 1 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 2 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 3 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 4 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 5 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 0 6 -1 -1 -Infinity -> i, j, dpi, aj, dpj: 1 2 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 6 -2 -1 -2 -> i, j, dpi, aj, dpj: 1 7 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 2 3 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 6 -2 -1 -2 -> i, j, dpi, aj, dpj: 2 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 2 8 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 3 4 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 6 -2 -1 -2 -> i, j, dpi, aj, dpj: 3 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 3 9 -2 -1 -Infinity -> i, j, dpi, aj, dpj: 4 5 -2 -1 -2 -> i, j, dpi, aj, dpj: 4 6 -2 -1 -2 -> i, j, dpi, aj, dpj: 4 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 4 9 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 6 -2 -1 -2 -> i, j, dpi, aj, dpj: 5 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 5 9 -2 -1 -3 -> i, j, dpi, aj, dpj: 6 7 -2 -1 -3 -> i, j, dpi, aj, dpj: 6 8 -2 -1 -3 -> i, j, dpi, aj, dpj: 6 9 -2 -1 -3 -> i, j, dpi, aj, dpj: 7 8 -3 -1 -3 -> i, j, dpi, aj, dpj: 7 9 -3 -1 -3 -> i, j, dpi, aj, dpj: 8 9 -3 -1 -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
function result: 1
function result: 15
function result: 2
function result: -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1, 2]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
function result: 3
function result: 15
function result: 2
function result: -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1, -100]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
function result: -99
function result: 15
function result: 2
function result: -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
[1, -100]
[1, 2, 3, 4, 5]
[1, -10, -1, -1, -1, -1, 1]
[-1, -1, -1, -1, -1, -1, -1, -1, -1, -1]
function result: -99
function result: 15
function result: 2
function result: -3
// you can write to stdout for debugging purposes, e.g.
// console.log('this is a debug message');
function solution(A) {
// write your code in JavaScript (Node.js 8.9.4)
let dp = Array.from({ length: A.length }, () => -Infinity);
dp[0] = A[0];
for (let i = 0; i < A.length; i++) {
for (let j = i + 1; j <= i + 6 && j < A.length; j++) {
// console.log('-> i, j, dpi, aj, dpj:', i, j, dp[i], A[j], dp[j])
dp[j] = Math.max(dp[j], dp[i] + A[j]);
}
}
return dp[dp.length - 1]
}
The solution obtained perfect score.