LeetCode417. Pacific Atlantic Water Flow

文章目录

一、题目

There is an m x n rectangular island that borders both the Pacific Ocean and Atlantic Ocean. The Pacific Ocean touches the island's left and top edges, and the Atlantic Ocean touches the island's right and bottom edges.

The island is partitioned into a grid of square cells. You are given an m x n integer matrix heights where heights[r][c] represents the height above sea level of the cell at coordinate (r, c).

The island receives a lot of rain, and the rain water can flow to neighboring cells directly north, south, east, and west if the neighboring cell's height is less than or equal to the current cell's height. Water can flow from any cell adjacent to an ocean into the ocean.

Return a 2D list of grid coordinates result where result[i] = [ri, ci] denotes that rain water can flow from cell (ri, ci) to both the Pacific and Atlantic oceans.

Example 1:

Input: heights = [[1,2,2,3,5],[3,2,3,4,4],[2,4,5,3,1],[6,7,1,4,5],[5,1,1,2,4]]

Output: [[0,4],[1,3],[1,4],[2,2],[3,0],[3,1],[4,0]]

Explanation: The following cells can flow to the Pacific and Atlantic oceans, as shown below:

0,4\]: \[0,4\] -\> Pacific Ocean \[0,4\] -\> Atlantic Ocean \[1,3\]: \[1,3\] -\> \[0,3\] -\> Pacific Ocean \[1,3\] -\> \[1,4\] -\> Atlantic Ocean \[1,4\]: \[1,4\] -\> \[1,3\] -\> \[0,3\] -\> Pacific Ocean \[1,4\] -\> Atlantic Ocean \[2,2\]: \[2,2\] -\> \[1,2\] -\> \[0,2\] -\> Pacific Ocean \[2,2\] -\> \[2,3\] -\> \[2,4\] -\> Atlantic Ocean \[3,0\]: \[3,0\] -\> Pacific Ocean \[3,0\] -\> \[4,0\] -\> Atlantic Ocean \[3,1\]: \[3,1\] -\> \[3,0\] -\> Pacific Ocean \[3,1\] -\> \[4,1\] -\> Atlantic Ocean \[4,0\]: \[4,0\] -\> Pacific Ocean \[4,0\] -\> Atlantic Ocean Note that there are other possible paths for these cells to flow to the Pacific and Atlantic oceans. Example 2: Input: heights = \[\[1\]

Output: [[0,0]]

Explanation: The water can flow from the only cell to the Pacific and Atlantic oceans.

Constraints:

m == heights.length

n == heights[r].length

1 <= m, n <= 200

0 <= heights[r][c] <= 105

二、题解

cpp 复制代码
class Solution {
public:
    int dirs[4][2] = {1,0,0,1,-1,0,0,-1};
    void dfs(vector<vector<int>>& heights,vector<vector<bool>>& visited,int x,int y){
        visited[x][y] = true;
        for(int i = 0;i < 4;i++){
            int nextX = x + dirs[i][0];
            int nextY = y + dirs[i][1];
            if(nextX < 0 || nextX >= heights.size() || nextY < 0 || nextY >= heights[0].size()) continue;
            if(heights[nextX][nextY] >= heights[x][y] && !visited[nextX][nextY]){
                dfs(heights,visited,nextX,nextY);
            }
        }
    }
    vector<vector<int>> pacificAtlantic(vector<vector<int>>& heights) {
        int m = heights.size(),n = heights[0].size();
        vector<vector<bool>> pacificVisited(m,vector<bool>(n,false));
        vector<vector<bool>> atlanticVisited(m,vector<bool>(n,false));
        //标记左右
        for(int i = 0;i < m;i++){
            dfs(heights,pacificVisited,i,0);
            dfs(heights,atlanticVisited,i,n-1);
        }
        //标记上下
        for(int j = 0;j < n;j++){
            dfs(heights,pacificVisited,0,j);
            dfs(heights,atlanticVisited,m-1,j);
        }
        vector<vector<int>> res;
        //统计结果
        for(int i = 0;i < m;i++){
            for(int j = 0;j < n;j++){
                if(pacificVisited[i][j] && atlanticVisited[i][j]){
                    res.push_back({i,j});
                }
            }
        }
        return res;
    }
};
相关推荐
玉米的玉*」*18 分钟前
【每日likou】704. 二分查找 27. 移除元素 977.有序数组的平方
数据结构·算法·leetcode
星火飞码iFlyCode20 分钟前
【无标题】
java·前端·人工智能·算法
lul~1 小时前
[科研理论]无人机底层控制算法PID、LQR、MPC解析
c++·人工智能·无人机
liulilittle1 小时前
OpenSSL 的 AES-NI 支持机制
linux·运维·服务器·算法·加密·openssl·解密
yzx9910131 小时前
柑橘检测模型
服务器·人工智能·深度学习·算法
南枝异客1 小时前
电话号码的字母组合
开发语言·javascript·算法
快乐肚皮1 小时前
快速排序:分治思想的经典实践
java·算法·排序算法
我命由我123452 小时前
STM32 开发 - 中断案例(中断概述、STM32 的中断、NVIC 嵌套向量中断控制器、外部中断配置寄存器组、EXTI 外部中断控制器、实例实操)
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·嵌入式
CodeWithMe3 小时前
【软件开发】上位机 & 下位机概念
c++
luofeiju3 小时前
数字图像处理与OpenCV初探
c++·图像处理·python·opencv·计算机视觉