417. 太平洋大西洋水流问题(2022-4-27)
有一个 m × n 的矩形岛屿,与 太平洋 和 大西洋 相邻。 “太平洋” 处于大陆的左边界和上边界,而 “大西洋” 处于大陆的右边界和下边界。
这个岛被分割成一个由若干方形单元格组成的网格。给定一个 m x n 的整数矩阵 heights , heights[r][c] 表示坐标 (r, c) 上单元格 高于海平面的高度 。
岛上雨水较多,如果相邻单元格的高度 小于或等于 当前单元格的高度,雨水可以直接向北、南、东、西流向相邻单元格。水可以从海洋附近的任何单元格流入海洋。
返回 网格坐标 result 的 2D列表 ,其中 result[i] = [ri, ci] 表示雨水可以从单元格 (ri, ci) 流向 太平洋和大西洋 。
示例请移步官网查看
解题思路
这题我也是看了几遍才明白他的意思,就是找到一块陆地,雨水能从这里开始流到大西洋和太平洋,这块陆地就有资格进入结果数组
ok直接逆向思维,从两片大海开始找高度「大于等于」当前陆块的内陆块,直到尽头;然后能够流向两片海的陆地,咱们用两个数组存储,最后求出数组的交集,就是能同时流向两片海的陆地。
方法一「DFS」:参考这里,因为我觉得他写的比较简洁;
状态数组初始为0,水能流到的记为1,如果当前陆地已经为1,就跳过避免重复搜索。
最后求出交集
const point = [0, 1, 0, -1, 0];
var pacificAtlantic = function(heights) {
const rowLen = heights.length;
const colLen = heights[0].length;
//记录从不同海洋能流动到当前位置话 值为1;
const dpPo = Array.from({
length: rowLen},()=>new Array(colLen)