양수로 이루어진 m x n 그리드를 인자로 드립니다. 상단 왼쪽에서 시작하여, 하단 오른쪽까지 가는 길의 요소를 다 더했을 때, 가장 작은 합을 찾아서 return 해주세요.
한 지점에서 우측이나 아래로만 이동할 수 있습니다.
Input:
[
[1,3,1],
[1,5,1],
[4,2,1]
]
Output: 7
Input:
[
[1,3,1],
[1,5,1],
[4,2,1]
]
Output: 7
설명: 1→3→1→1→1 의 합이 제일 작음
const minPathSum = grid => {
//일단 첫 row와 첫 column은 각각, 그 path로 갔다고 생각하고 더해놓는다.
for (let i = 1; i < grid.length; i++) {
grid[i][0] += grid[i-1][0];
}
for (let i = 1; i < grid[0].length; i++) {
grid[0][i] += grid[0][i-1];
}
for (let i = 1; i < grid.length; i++) {
for (let j = 1; j < grid[0].length; j++) {
//위쪽이나 왼쪽에서, 더 작은걸로 더해준다.
grid[i][j] += Math.min(grid[i-1][j], grid[i][j-1]);
}
}
return grid[grid.length-1]grid[0].length-1];
};
console.log(minPathSum([[1,2,3],[4,1,2]]));
//output :6