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

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

查看所有标签

猜你喜欢:

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

精通Web Analytics 2.0

精通Web Analytics 2.0

[美]Avinash Kaushik / 郑海平、邓天卓 / 清华大学出版社 / 2011-4-26 / 48.00元

向数据驱动型决策转变以及如何利用网站数据来获得竞争优势 在过去几年中,互联网、在线营销以及广告经历了巨大的变革,然而大家处理数据的方式跟几十年前相比还是大同小异,停滞不前。网站分析领域的领跑者Analytics kaushik通过《精通Web Analytics 2.0——用户中心科学与在线统计艺术》提出了下一代网站分析的框架,将能很大程度地帮助你提高组织的能动性和对市场的反应速度。 ......一起来看看 《精通Web Analytics 2.0》 这本书的介绍吧!

RGB转16进制工具
RGB转16进制工具

RGB HEX 互转工具

html转js在线工具
html转js在线工具

html转js在线工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具