这种动态规划还行

class Solution {
    public int maxValue(int[][] grid) {

        if(grid[0].length == 0) return 0;

        int[][] dp = new int[grid.length][grid[0].length];
        dp[0][0] = grid[0][0];

        for(int i=1; i< grid[0].length; i++) dp[0][i] = dp[0][i-1] + grid[0][i];
        for(int i=1; i< grid.length; i++) dp[i][0] = dp[i-1][0] + grid[i][0];

        for(int i=1; i<grid.length ; i++){
            for(int j = 1; j<grid[0].length ; j++){
                dp[i][j] = Math.max(dp[i-1][j],dp[i][j-1]) + grid[i][j];
            }
        }

        return dp[grid.length-1][grid[0].length-1];

    }
}