【多源 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;
 }
}
相关推荐
仰泳的熊猫1 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码4 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发4 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre5 小时前
22 括号生成
算法·深度优先
努力也学不会java6 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎6 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan7 小时前
朱梁万有递归元定理,重构《易经》
算法·重构
智者知已应修善业7 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
khddvbe8 小时前
C++并发编程中的死锁避免
开发语言·c++·算法