Leetcode 1219 黄金矿工 暴力回溯

 

  回溯解法:

    int an = 0;

    public final int getMaximumGold(int[][] grid) {
        for (int i = 0; i < grid.length; i++) {
            for (int j = 0; j < grid[0].length; j++) {
                getMaximumGold(grid, i, j, 0);
            }
        }
        return an;
    }

    public final void getMaximumGold(int[][] grid, int x, int y, int sum) {
        if (x >= grid.length || x < 0 || y >= grid[0].length || y < 0 || grid[x][y] == 0 || grid[x][y] == -1) {
            an = Math.max(an, sum);
            return;
        }
        int current = grid[x][y];
        int currentSum = sum + current;
        grid[x][y] = -1;
        getMaximumGold(grid, x + 1, y, currentSum);
        getMaximumGold(grid, x - 1, y, currentSum);
        getMaximumGold(grid, x, y + 1, currentSum);
        getMaximumGold(grid, x, y - 1, currentSum);
        grid[x][y] = current;
    }

 

 

  

posted @ 2020-07-15 15:16  牛有肉  阅读(211)  评论(0编辑  收藏  举报