当前位置: 首页 > news >正文

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

多源 BFS

  • 3.地图中的最⾼点(medium)
    • 题⽬描述:
    • 解法:
      • 算法思路:
    • 算法代码:

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 解决即可。

算法代码:

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. 多源 bfswhile(!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;}
}
http://www.dtcms.com/a/611263.html

相关文章:

  • 网站建设需要学代码吗巴中企业网站建设
  • 开发网站公司交税网站建设php的心得和体会
  • 超参数调优:Grid Search 和 Random Search 的实战对比
  • 编译语言有哪些 | 探索编译语言的种类及其应用领域
  • 网站的弹窗是怎么做的ol游戏大全排行榜
  • 玩转Docker | 使用Docker部署Tomcat服务器
  • RHCA - DO374 | Day06:管理任务执行
  • html5移动网站开发实践做招聘信息的网站有哪些内容
  • 天际股份、天赐材料、多氟多、永太科技、联化科技、深圳新星,6家龙头公司研发实力深度数据
  • 北京公司注册核名网站网络营销业务流程
  • 常用的设计网站有哪些如何查询一个网站的空间大小
  • 【题解】洛谷 P2330 [SCOI2005] 繁忙的都市 [生成树]
  • 创建网站鞍山站
  • 网站建设规划书河北浏览器大全网址
  • 物理层数字调制技术介绍
  • 手机网站排名优化网站网络营销怎么做
  • 服装网站建设目标客户新闻发布网站如果做
  • C语言在线编译运行 | 提供高效便捷的编程学习平台
  • 响应式网站开发方法用jquery做网站好吗
  • 【论文阅读17】-结合大模型与小模型的类脑认知驱动模型工厂在工业物联网故障诊断中的应用
  • 商贸公司营销网站建设新媒体网站建设费用详单
  • 连城县住房和城乡建设局 网站顺德互动交流网站
  • 线程池原理复习
  • 营销型网站特征wordpress用户中心模板
  • 上下文中使用异步IO
  • 建设部注册师网站苏州手机网站制作
  • 【数据库管理】MySQL主从复制详解
  • 企业网站建设算什么费用西安全网优化
  • 营销型企业网站优点文凭快速拿证
  • wordpress相对路径设置刷百度关键词排名优化