穷举vs暴搜vs深搜vs回溯vs剪枝系列一>黄金矿工

目录

决策树:

代码设计

代码:

java 复制代码
class Solution {
    boolean[][] vis;
    int ret,m,n;

    public int getMaximumGold(int[][] grid) {
        m = grid.length;
        n = grid[0].length;
        vis = new boolean[m][n]; 

        for(int i = 0; i < m; i++)
            for(int j = 0; j < n; j++){
                //剪枝
                if (grid[i][j] != 0 && !vis[i][j]){
                    vis[i][j] = true;
                    dfs(grid,i,j,grid[i][j]);
                    vis[i][j] = false;//回溯
                }
            }

        return ret;    
    }

    int[] dx = {-1,1,0,0};
    int[] dy = {0,0,-1,1};
    //这里局部变量会自己恢复现场
    private void dfs(int[][] grid, int i, int j, int path){

        ret = Math.max(ret,path);
        
        for(int k = 0; k < 4; k++){
            int x = i + dx[k];
            int y = j + dy[k];
            //剪枝
            if(x >= 0 && x < m && y >= 0 && y < n && !vis[x][y] && grid[x][y] != 0){
                vis[x][y] = true;
                dfs(grid,x,y,path + grid[x][y]);
                vis[x][y] = false;//回溯
            }
        }
    }
}
相关推荐
恣艺2 小时前
LeetCode 1074:元素和为目标值的子矩阵数量
算法·leetcode·矩阵
queenlll2 小时前
P1064 [NOIP 2006 提高组] 金明的预算方案 题解
算法
WildBlue3 小时前
前端算法秘籍:BFS 算法的 JS 魔法之旅🤩
前端·javascript·算法
设计师小聂!3 小时前
力扣---------238. 除自身以外数组的乘积
数据结构·算法·leetcode
minji...4 小时前
数据结构 二叉树(2)---二叉树的实现
数据结构·算法
草香农4 小时前
Keccak 算法详解
算法
荒诞硬汉5 小时前
二维数组相关学习
java·算法
周末程序猿5 小时前
技术总结|如何使用提升 strlen 的性能?
后端·算法
菜鸟555555 小时前
图论:Dijkstra算法
算法·图论·dijkstra·xcpc
科大饭桶6 小时前
数据结构自学Day15 -- 非比较排序--计数排序
数据结构·算法·leetcode·排序算法·c