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

多源 BFS

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

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

题⽬描述:

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

图。

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

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

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

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

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

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

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

请你返回⼀个⼤⼩为 m x n 的整数矩阵 height ,其中 height[i][j] 是格⼦ (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 = = isWater[i].length

◦ 1 <= m, n <= 1000

◦ isWater[i][j] 要么是 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;
 }
}
相关推荐
weisian15116 分钟前
Java并发编程--47-分布式ID生成器:雪花算法(Snowflake)与时钟回拨问题
java·算法·时钟回拨·雪花算法id
itzixiao17 分钟前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr87318 分钟前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
小饕21 分钟前
从 Word2Vec 到多模态:词嵌入技术的演进全景
人工智能·算法·机器学习
海参崴-23 分钟前
AVL树完整实现与深度解析
算法
一个爱编程的人30 分钟前
一个数是不是素数
数据结构·算法
Hui_AI72035 分钟前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
lwf00616436 分钟前
FFM (Field-aware Factorization Machine) 学习日记
算法·机器学习
南宫萧幕36 分钟前
HEV能量管理控制算法实战:从MPC/RL理论基础到Simulink闭环建模
算法·matlab·汽车·控制·pid
IT猿手43 分钟前
SCI一区:章鱼优化算法(Octopus Optimization Algorithm, OOA)求解23个测试函数,出图丰富,提供完整MATLAB代码
开发语言·算法·matlab