力扣(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);
    }
    
    
    
}

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

查看所有标签

猜你喜欢:

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

共享经济

共享经济

[美] 罗宾•蔡斯 / 王芮 / 浙江人民出版社 / 2015-9-25 / 59.90元

[内容简介]  在当今这个稀缺的世界里,人人共享组织可以创造出富足。通过利用已有的资源,如有形资产、技术、网络、设备、数据、经验和流程等,这些组织可以以指数级成长。人人共享重新定义了我们对于资产的理解:它是专属于个人的还是大众的;是私有的还是公有的;是商业的还是个人的,并且也让我们对监管、保险以及管理有了重新的思索。  在这本书中,罗宾与大家分享了以下观点:  如何利用过剩......一起来看看 《共享经济》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

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

在线 XML 格式化压缩工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试