LeetCode:1219.黄金矿工(Java语言)

简介: LeetCode:1219.黄金矿工(Java语言)

1219.黄金矿工

你要开发一座金矿,地质勘测学家已经探明了这座金矿中的资源分布,并用大小为 m * n 的网格 grid 进行了标注。每个单元格中的整数就表示这一单元格中的黄金数量;如果该单元格是空的,那么就是 0。

为了使收益最大化,矿工需要按以下规则来开采黄金:

每当矿工进入一个单元,就会收集该单元格中的所有黄金。

矿工每次可以从当前位置向上下左右四个方向走。

每个单元格只能被开采(进入)一次。

不得开采(进入)黄金数目为 0 的单元格。

矿工可以从网格中 任意一个 有黄金的单元格出发或者是停止。

示例1:

输入:grid = [[0,6,0],[5,8,7],[0,9,0]]

输出:24

解释:

[[0,6,0],

[5,8,7],

[0,9,0]]

一种收集最多黄金的路线是:9 -> 8 -> 7。

示例2:

输入:grid = [[1,0,7],[2,0,6],[3,4,5],[0,3,0],[9,0,20]]

输出:28

解释:

[[1,0,7],

[2,0,6],

[3,4,5],

[0,3,0],

[9,0,20]]

一种收集最多黄金的路线是:1 -> 2 -> 3 -> 4 -> 5 -> 6 -> 7。

解题思路:

  • 因为要找最大值,所以要遍历每个顶点,对其进行深度优先遍历
  • 如果遇到边界或者是已访问顶点则返回
  • 和之前的题差不多,就是进行回溯
  • 矿工可以向各个方向走,所以对每个方向进行dfs搜索
  • 最后找各个方向的最大值。

代码:

/**
 *作者:魏宝航
 *2020年11月30日,上午7:53
 */
class Solution {
    boolean[][] visit;
    public int getMaximumGold(int[][] grid) {
        visit=new boolean[grid.length][grid[0].length];
        int res=0;
        if(grid==null||grid.length==0){
            return 0;
        }
        for(int i=0;i<grid.length;i++){
            for(int j=0;j<grid[0].length;j++){
                res=Math.max(res,dfs(grid,i,j));
            }
        }
        return res;
    }
    public int dfs(int[][] grid,int i,int j){
        if(i<0||i==grid.length||j<0||j==grid[0].length||visit[i][j]||grid[i][j]==0){
            return 0;
        }
        visit[i][j]=true;
        int up=dfs(grid,i-1,j);
        int down=dfs(grid,i+1,j);
        int left=dfs(grid,i,j-1);
        int right=dfs(grid,i,j+1);
        int max=up>down?up:down;
        max=max>left?max:left;
        max=max>right?max:right;
        visit[i][j]=false;
        return grid[i][j]+max;
    }
}

测试结果:


目录
相关文章
|
2月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
90 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
24天前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
4月前
|
Java Maven
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
该博客文章介绍了如何使用Java Swing中的JFrame创建一个窗体来收集用户输入的内容,并提供了详细的实现步骤和完整代码示例。
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
|
1月前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
49 4
|
2月前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
56 3
|
2月前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
86 4
|
2月前
|
存储 Java 数据安全/隐私保护
Java中的域,什么是域?计算机语言中的域是什么?(有代码实例)
文章解释了Java中域的概念,包括实例域、静态域、常量域和局部域,以及它们的特点和使用场景。
70 2
|
2月前
|
Java 数据安全/隐私保护 C++
Java语言关键字
Java语言关键字
28 2
|
2月前
|
分布式计算 安全 Java
Java语言的特点?
Java语言的特点?
|
2月前
|
算法 Java
LeetCode(一)Java
LeetCode(一)Java