leetCode-Record icon indicating copy to clipboard operation
leetCode-Record copied to clipboard

面试题47. 礼物的最大价值

Open fireairforce opened this issue 5 years ago • 0 comments

很裸的动态规划,dp[i][j] = Math.max(dp[i-1][j],dp[i][j - 1]) + grid[i][j]

/**
 * @param {number[][]} grid
 * @return {number}
 */
var maxValue = function(grid) {
  let m = grid.length
  if (m === 0) {
    return 0
  }
  let n = grid[0].length
  let dp = []
  for (let i = 0; i < m; i++) {
    dp[i] = new Array()
    for (let j = 0; j < n; j++) {
      dp[i][j] = 0
    }
  }
  dp[0][0] = grid[0][0]
  for (let i = 0; i < m; i++) {
    for (let j = 0; j < n; j++) {
      if (i === 0 && j !== 0) {
        dp[i][j] += grid[i][j] + dp[i][j - 1]
      } else if (i !== 0 && j === 0) {
        dp[i][j] += grid[i][j] + dp[i - 1][j]
      }
    }
  }
  for (let i = 1; i < m; i++) {
    for (let j = 1; j < n; j++) {
      dp[i][j] = Math.max(dp[i - 1][j], dp[i][j - 1]) + grid[i][j]
    }
  }
  return dp[m - 1][n - 1]
}

fireairforce avatar Feb 29 '20 08:02 fireairforce