递归、搜索与回溯-综合练习:27.黄金矿工

题目链接:1219. 黄金矿工(中等)

算法原理:

解法:DFS

枚举矩阵中所以位置为起点来一次dfs,取最大值

Java代码:

java 复制代码
/**
 * Created with IntelliJ IDEA.
 * Description:
 * User: 王洋
 * Date: 2025-10-09
 * Time: 12:29
 */
class Solution {
    //1219. 黄金矿工
    boolean[][] check;
    int m,n;
    int max;
    public int getMaximumGold(int[][] grid) {
        m=grid.length;n=grid[0].length;
        max=0;
        check=new boolean[m][n];
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(!check[i][j]&&grid[i][j]!=0){
                    check[i][j]=true;
                    //2.调用返回总和的dfs,用结果更新max,删除提前返回的return
                    max=Math.max(max,dfs(grid,i,j));
                    check[i][j]=false;
                }
            }
        }
        return max;
    }
    int[] dx=new int[]{0,0,-1,1};
    int[] dy=new int[]{1,-1,0,0};
    //返回值不用boolean,改为int
    public int dfs(int[][] grid,int i,int j){
        int tmp=0;
        for(int k=0;k<4;k++){
            int x=i+dx[k],y=j+dy[k];
            if(x<m&&y<n&&x>=0&&y>=0&&!check[x][y]&&grid[x][y]!=0){
                check[x][y]=true;
                //递归获取后续路径总和,取最大值
                tmp=Math.max(tmp,dfs(grid,x,y));
                check[x][y]=false;
            }
        }
        //返回格子值+后续路径最大值总和
        return grid[i][j]+tmp;
    }
    //看完吴小哲的代码后自己写了一遍,一遍过
    //dfs不用返回值,path作局部变量递归
    boolean[][] check;
    int m,n;
    int ret;
    public int getMaximumGold(int[][] grid) {
        m=grid.length;n=grid[0].length;
        check=new boolean[m][n];
        for(int i=0;i<m;i++){
            for(int j=0;j<n;j++){
                if(!check[i][j]&&grid[i][j]!=0){
                    check[i][j]=true;
                    dfs(grid,i,j,grid[i][j]);
                    check[i][j]=false;
                }
            }
        }
        return ret;
    }
    int[] dx=new int[]{0,0,1,-1};
    int[] dy=new int[]{-1,1,0,0};
    public 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],y=j+dy[k];
            if(x<m&&y<n&&x>=0&&y>=0&&!check[x][y]&&grid[x][y]!=0){
                check[x][y]=true;
                dfs(grid,x,y,grid[x][y]+path);
                check[x][y]=false;
            }
        }
    }
}
相关推荐
Coder_Boy_3 分钟前
Deeplearning4j+ Spring Boot 电商用户复购预测案例
java·人工智能·spring boot·后端·spring
踢足球092911 分钟前
寒假打卡:2026-2-7
java·开发语言·javascript
闻哥13 分钟前
Kafka高吞吐量核心揭秘:四大技术架构深度解析
java·jvm·面试·kafka·rabbitmq·springboot
金牌归来发现妻女流落街头15 分钟前
【Springboot基础开发】
java·spring boot·后端
_OP_CHEN22 分钟前
【算法基础篇】(五十七)线性代数之矩阵乘法从入门到实战:手撕模板 + 真题详解
线性代数·算法·矩阵·蓝桥杯·c/c++·矩阵乘法·acm/icpc
天天爱吃肉821827 分钟前
【跨界封神|周杰伦×王传福(陶晶莹主持):音乐创作与新能源NVH测试,底层逻辑竟完全同源!(新人必看入行指南)】
python·嵌入式硬件·算法·汽车
im_AMBER28 分钟前
Leetcode 114 链表中的下一个更大节点 | 删除排序链表中的重复元素 II
算法·leetcode
考琪31 分钟前
Nginx打印变量到log方法
java·运维·nginx
xhbaitxl40 分钟前
算法学习day38-动态规划
学习·算法·动态规划
多恩Stone41 分钟前
【3D AICG 系列-6】OmniPart 训练流程梳理
人工智能·pytorch·算法·3d·aigc