穷举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;//回溯
            }
        }
    }
}
相关推荐
小庞在加油31 分钟前
《dlib库中的聚类》算法详解:从原理到实践
c++·算法·机器学习·数据挖掘·聚类
ComputerInBook34 分钟前
C++ 标准模板库算法之 transform 用法
开发语言·c++·算法·transform算法
hn小菜鸡7 小时前
LeetCode 377.组合总和IV
数据结构·算法·leetcode
Deepoch7 小时前
Deepoc 大模型:无人机行业的智能变革引擎
人工智能·科技·算法·ai·动态规划·无人机
heimeiyingwang9 天前
【深度学习加速探秘】Winograd 卷积算法:让计算效率 “飞” 起来
人工智能·深度学习·算法
时空自由民.9 天前
C++ 不同线程之间传值
开发语言·c++·算法
ai小鬼头9 天前
AIStarter开发者熊哥分享|低成本部署AI项目的实战经验
后端·算法·架构
小白菜3336669 天前
DAY 37 早停策略和模型权重的保存
人工智能·深度学习·算法
zeroporn9 天前
以玄幻小说方式打开深度学习词嵌入算法!! 使用Skip-gram来完成 Word2Vec 词嵌入(Embedding)
人工智能·深度学习·算法·自然语言处理·embedding·word2vec·skip-gram
亮亮爱刷题10 天前
飞往大厂梦之算法提升-7
数据结构·算法·leetcode·动态规划