【多源 BFS】3.地图中的最⾼点(medium)

多源 BFS

3.地图中的最⾼点(medium)

题⽬链接:1765. 地图中的最⾼点

题⽬描述:

给你⼀个⼤⼩为 m x n 的整数矩阵 isWater ,它代表了⼀个由 陆地 和 ⽔域 单元格组成的地

图。

• 如果 isWaterij = = 0 ,格⼦ (i, j) 是⼀个 陆地 格⼦。

• 如果 isWaterij = = 1 ,格⼦ (i, j) 是⼀个 ⽔域 格⼦。

你需要按照如下规则给每个单元格安排⾼度:

• 每个格⼦的⾼度都必须是⾮负的。

• 如果⼀个格⼦是 ⽔域 ,那么它的⾼度必须为 0 。

• 任意相邻的格⼦⾼度差 ⾄多 为 1 。当两个格⼦在正东、南、西、北⽅向上相互紧挨着,就称它们为相邻的格⼦。(也就是说它们有⼀条公共边)

找到⼀种安排⾼度的⽅案,使得矩阵中的最⾼⾼度值 最⼤ 。

请你返回⼀个⼤⼩为 m x n 的整数矩阵 height ,其中 heightij 是格⼦ (i, j) 的⾼度。如果有多种解法,请返回 任意⼀个 。

⽰例 1:

输⼊:isWater = \[0,1,0,0]

输出:\[1,0,2,1]

解释:上图展⽰了给各个格⼦安排的⾼度。

蓝⾊格⼦是⽔域格,绿⾊格⼦是陆地格。

⽰例 2:

输⼊:isWater = \[0,0,1,1,0,0,0,0,0]

输出:\[1,1,0,0,1,1,1,2,2]

解释:所有安排⽅案中,最⾼可⾏⾼度为 2 。

任意安排⽅案中,只要最⾼⾼度为 2 且符合上述规则的,都为可⾏⽅案。

提⽰:

◦ m = = isWater.length

◦ n = = isWateri.length

◦ 1 <= m, n <= 1000

◦ isWaterij 要么是 0 ,要么是 1 。

◦ ⾄少有 1 个⽔域格⼦。

解法:

算法思路:

01矩阵的变型题,直接⽤多源 bfs 解决即可。

算法代码:

java 复制代码
class Solution
{
 int[] dx = {0, 0, -1, 1};
 int[] dy = {1, -1, 0, 0};
 public int[][] highestPeak(int[][] isWater) 
 {
 	 int m = isWater.length, n = isWater[0].length;
	 int[][] dist = new int[m][n];
	 for(int i = 0; i < m; i++)
	 for(int j = 0; j < n; j++)
	 dist[i][j] = -1;
	 Queue<int[]> q = new LinkedList<>();
	 // 1. 所有的源点加⼊到队列⾥⾯
	 for(int i = 0; i < m; i++)
	 for(int j = 0; j < n; j++)
	 if(isWater[i][j] == 1)
	 {
		 q.add(new int[]{i, j});
		 dist[i][j] = 0;
	 }
	 // 2. 多源 bfs
	 while(!q.isEmpty())
	 {
		 int[] t = q.poll();
		 int a = t[0], b = t[1];
		 for(int i = 0; i < 4; i++)
		 {
			 int x = a + dx[i], y = b + dy[i];
			 if(x >= 0 && x < m && y >= 0 && y < n && dist[x][y] == -1)
			 {
				 dist[x][y] = dist[a][b] + 1;
				 q.add(new int[]{x, y});
			 }
		 }
	 }
	 return dist;
 }
}
相关推荐
菜鸡爱玩3 小时前
线性代数矩阵相乘
线性代数·算法·矩阵
devilnumber7 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
‎ദ്ദിᵔ.˛.ᵔ₎9 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾9 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090969 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan201609 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v10 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程10 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时11 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript