zoukankan      html  css  js  c++  java
  • 【bfs,动态规划,Dijkstra】1162. 地图分析

    你现在手里有一份大小为 N x N 的『地图』(网格) grid,上面的每个『区域』(单元格)都用0 1 标记好了。其中0代表海洋,1 代表陆地,你知道距离陆地区域最远的海洋区域是是哪一个吗?请返回该海洋区域到离它最近的陆地区域的距离。

    我们这里说的距离是『曼哈顿距离』( Manhattan Distance):(x0, y0) 和 (x1, y1) 这两个区域之间的距离是|x0 - x1| + |y0 - y1|

    如果我们的地图上只有陆地或者海洋,请返回 -1
    在这里插入图片描述
    方法一: bfs

    import java.util.LinkedList;
    import java.util.Queue;
    
    class Solution {
        int R;
        int C;
        int[][] dirs = {{-1, 0}, {0, 1}, {1, 0}, {0, -1}};
        boolean[][] visited;
        int[][] depth;
    
        public int maxDistance(int[][] grid) {
            this.R = grid.length;
            this.C = grid[0].length;
            if (check(grid, R, C)) {
                return -1;
            }
            depth = new int[R][C];
            for (int i = 0; i < R; i++) {
                for (int j = 0; j < C; j++) {
                    if (grid[i][j] == 1) {
                        visited = new boolean[R][C];
                        bfs(grid, i, j);
                    }
                }
            }
            int max = 0;
            for (int i = 0; i < R; i++) {
                for (int j = 0; j < C; j++) {
                    max = Math.max(max,depth[i][j]);
                }
            }
            return max;
        }
    
        private void bfs(int[][] grid, int x, int y) {
            visited[x][y] = true;
            Queue<Integer> que = new LinkedList<>();
            que.add(x * C + y);
            while (!que.isEmpty()) {
                int poll = que.remove();
                x = poll / C;
                y = poll % C;
                for (int d = 0; d < 4; d++) {
                    int nextx = x + dirs[d][0];
                    int nexty = y + dirs[d][1];
                    if (inArea(nextx, nexty) && grid[nextx][nexty] == 0 && !visited[nextx][nexty]) {
                        visited[nextx][nexty] = true;
                        depth[nextx][nexty] = Math.min(depth[nextx][nexty] == 0 ? 9999 : depth[nextx][nexty], depth[x][y] + 1);
                        que.add(nextx * C + nexty);
                    }
                }
            }
        }
    
        private boolean inArea(int nextx, int nexty) {
            return nextx >= 0 && nextx < R && nexty >= 0 && nexty < C;
        }
    
        private boolean check(int[][] grid, int r, int c) {
            int zeroCount = 0;
            int oneCount = 0;
            for (int i = 0; i < r; i++) {
                for (int j = 0; j < c; j++) {
                    if (grid[i][j] == 0) {
                        zeroCount++;
                    } else
                        oneCount++;
                }
            }
            return zeroCount == 0 || oneCount == 0;
        }
    }
    

    方法二:多元最短路径
    方法三:动态规划

  • 相关阅读:
    java四种线程池的使用
    @Autowired@Resource@Qualifier的区别
    Unsupported major.minor version 52.0解决办法
    CentOS7配置防火墙
    redis 集群搭建
    excludepathpatterns 无效
    解决 SpringBoot 没有主清单属性
    Java Web应用中调优线程池的重要性
    spring boot application properties配置详解
    Class path contains multiple SLF4J bindings.
  • 原文地址:https://www.cnblogs.com/HoweZhan/p/12591814.html
Copyright © 2011-2022 走看看