力扣(LeetCode)417

栏目: 编程工具 · 发布时间: 5年前

内容简介:题目地址:题目描述:

题目地址:

https://leetcode-cn.com/probl...

题目描述:

给定一个 m x n 的非负整数矩阵来表示一片大陆上各个单元格的高度。“太平洋”处于大陆的左边界和上边界,而“大西洋”处于大陆的右边界和下边界。

规定水流只能按照上、下、左、右四个方向流动,且只能从高到低或者在同等高度上流动。

请找出那些水流既可以流动到“太平洋”,又能流动到“大西洋”的陆地单元的坐标。

解答:

反向思维,某个地方可以流向大西洋或太平洋,我们把它理解为太平洋或者大西洋可以流向某个区域,这样一来只需要从大西洋或者太平样的节点进行深度优先搜索即可。只不过原来的流动条件是高往低流,现在变为低往高流。

java ac代码:

class Solution {
    
            
    boolean[][]left;
    boolean[][]right;
    boolean[][] flag1;
    boolean[][] flag2;
    
    public List<int[]> pacificAtlantic(int[][] matrix) {
        List<int[]> ans = new ArrayList(1000);
        if(matrix.length == 0)return ans;
        
        left = new boolean[matrix.length][matrix[0].length];
        right = new boolean[matrix.length][matrix[0].length];
        flag1 = new boolean[matrix.length][matrix[0].length];
        flag2 = new boolean[matrix.length][matrix[0].length];
        
        
        for(int i = 0;i < matrix.length;i++)
        {
            dfsleft(matrix,flag1,i,0);
            dfsright(matrix,flag2,i,matrix[0].length-1);
        }
        for(int i = 0;i < matrix[0].length;i++)
        {
            dfsleft(matrix,flag1,0,i);
            dfsright(matrix,flag2,matrix.length-1,i);
        }
        for(int i = 0;i < matrix.length;i++)
            for(int j = 0;j < matrix[0].length;j++)
                if(left[i][j] && right[i][j])
                    ans.add(new int[]{i,j});
        return ans;
        
    }
    
    void dfsleft(int[][] matrix,boolean[][]flag,int x,int y)
    {
        if(flag[x][y])return;
        flag[x][y] = true;
        left[x][y] = true;
        if((x-1 >= 0 && x-1 < matrix.length && y >= 0 && y< matrix[0].length) && matrix[x-1][y] >= matrix[x][y])
            dfsleft(matrix,flag,x-1,y);
        if((x+1 >= 0 && x+1 < matrix.length && y >= 0 && y< matrix[0].length) && matrix[x+1][y] >= matrix[x][y])
            dfsleft(matrix,flag,x+1,y);
        if((x >= 0 && x < matrix.length && y-1 >= 0 && y-1< matrix[0].length) && matrix[x][y-1] >= matrix[x][y])
            dfsleft(matrix,flag,x,y-1);
        if((x >= 0 && x < matrix.length && y+1 >= 0 && y+1< matrix[0].length) && matrix[x][y+1] >= matrix[x][y])
            dfsleft(matrix,flag,x,y+1);
    }
    
    
    void dfsright(int[][] matrix,boolean[][]flag,int x,int y)
    {
        if(flag[x][y])return;
        flag[x][y] = true;

        right[x][y] = true;
        if((x-1 >= 0 && x-1 < matrix.length && y >= 0 && y< matrix[0].length) && matrix[x-1][y] >= matrix[x][y])
            dfsright(matrix,flag,x-1,y);
        if((x+1 >= 0 && x+1 < matrix.length && y >= 0 && y< matrix[0].length) && matrix[x+1][y] >= matrix[x][y])
            dfsright(matrix,flag,x+1,y);
        if((x >= 0 && x < matrix.length && y-1 >= 0 && y-1< matrix[0].length) && matrix[x][y-1] >= matrix[x][y])
            dfsright(matrix,flag,x,y-1);
        if((x >= 0 && x < matrix.length && y+1 >= 0 && y+1< matrix[0].length) && matrix[x][y+1] >= matrix[x][y])
            dfsright(matrix,flag,x,y+1);
    }
    
    
    
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

如何求解问题

如何求解问题

Zbigniew Michalewicz、David B.Fogel / 曹宏庆 / 中国水利水电出版社 / 2003-2-1 / 35.00元

《如何求解问题:现代启发式方法》通过一系列贯穿于章节间的有趣难题,《如何求解问题:现代启发式方法》深入浅出地阐述了如何利用计算机来求解问题的一些现代启发式方法。全书包括两部分,共分15章。一起来看看 《如何求解问题》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具