代码随想录 417.太平洋大西洋水流问题

思路:本题的起点(所求答案)不明确,但是终点(上下左右四个边界)明确。所以从边界出发可以更方便地找到答案。

1.边界:heights中的i = 0或者i = m - 1;或者j = 0或者j = n - 1的格子。

2.答案:既可流向太平洋也可流向大西洋的格子。

(1)对于可流向太平洋的格子,从上边界(i = 0)和左边界(j = 0)倒着往高处走,所有能访问到的格子都是可以流向太平洋的格子。

(2)对于可流向大西洋的格子,从下边界(i = m - 1)和右边界(j = n - 1)倒着往高处走,所有能访问到的格子都是可以流向大西洋的格子。

(3)注意:左下角和右上角的海水既是大西洋又是太平洋。

3.计算这两类格子的交集,就是既可流向太平洋也可流向大西洋的格子。

附代码:

java 复制代码
class Solution {
    //左右上下
    private static final int[][] DIRS = {{0,-1},{0,1},{-1,0},{1,0}};
    public List<List<Integer>> pacificAtlantic(int[][] heights) {
        int m = heights.length,n = heights[0].length;

        //从太平洋边界出发
        boolean[][] pacificVis = new boolean[m][n];
        for(int j = 0;j < n;j++){
            dfs(0,j,pacificVis,heights); //上边界
        }
        for(int i = 1;i < m;i++){
            dfs(i,0,pacificVis,heights); //左边界,i从1开始是因为(0,0)已经包含在上边界中
        }

        //从大西洋边界出发
        boolean[][] atlanticVis = new boolean[m][n];
        for(int j = 0;j < n;j++){
            dfs(m - 1,j,atlanticVis,heights); //下边界
        }
        for(int i = 0;i < m - 1;i++){
            dfs(i,n - 1,atlanticVis,heights); //右边界 最后一列是m - 2是因为(m - 1,n - 1)已经包含在下边界中
        }

        //交集即为答案
        List<List<Integer>> res = new ArrayList<>();
        for(int i = 0;i < m;i++){
            for(int j = 0;j < n;j++){
                if(pacificVis[i][j] && atlanticVis[i][j]){
                    res.add(List.of(i,j));
                }
            }
        }
        return res;
    }
    private void dfs(int i,int j,boolean[][] vis,int[][] heights){
        if(vis[i][j]){ //避免重复访问,避免反复横跳无限递归
            return;
        }
        vis[i][j] = true; //标记(i,j)已访问
        for(int[] d : DIRS){//枚举相邻格子
            int x = i + d[0],y = j + d[1];
            if(x >= 0 && x < heights.length && y >= 0 && y < heights[x].length && heights[x][y] >= heights[i][j]){
                //往高处走
                dfs(x,y,vis,heights);
            }
        }
    }
}
相关推荐
m0_7487080515 分钟前
C++中的观察者模式实战
开发语言·c++·算法
然哥依旧15 分钟前
【轴承故障诊断】基于融合鱼鹰和柯西变异的麻雀优化算法OCSSA-VMD-CNN-BILSTM轴承诊断研究【西储大学数据】(Matlab代码实现)
算法·支持向量机·matlab·cnn
qq_5375626728 分钟前
跨语言调用C++接口
开发语言·c++·算法
Tingjct40 分钟前
【初阶数据结构-二叉树】
c语言·开发语言·数据结构·算法
C雨后彩虹40 分钟前
计算疫情扩散时间
java·数据结构·算法·华为·面试
yyy(十一月限定版)1 小时前
寒假集训4——二分排序
算法
星火开发设计1 小时前
类型别名 typedef:让复杂类型更简洁
开发语言·c++·学习·算法·函数·知识
醉颜凉2 小时前
【LeetCode】打家劫舍III
c语言·算法·leetcode·树 深度优先搜索·动态规划 二叉树
达文汐2 小时前
【困难】力扣算法题解析LeetCode332:重新安排行程
java·数据结构·经验分享·算法·leetcode·力扣
一匹电信狗2 小时前
【LeetCode_21】合并两个有序链表
c语言·开发语言·数据结构·c++·算法·leetcode·stl