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

每日一题:Leet 2257. 统计网格图中没有被保卫的格子数

给你两个整数mn表示一个下标从 0 开始的m x n网格图。同时给你两个二维整数数组guardswalls,其中guards[i] = [rowi, coli]walls[j] = [rowj, colj],分别表示第i个警卫和第j座墙所在的位置。

一个警卫能看到 4 个坐标轴方向(即东、南、西、北)的所有格子,除非他们被一座墙或者另外一个警卫挡住了视线。如果一个格子能被至少一个警卫看到,那么我们说这个格子被保卫了。

请你返回空格子中,有多少个格子是没被保卫 的。

示例:
image

输入:m = 4, n = 6, guards = [[0,0],[1,1],[2,3]], walls = [[0,1],[2,2],[1,4]]
输出:7
解释:上图中,被保卫和没有被保卫的格子分别用红色和绿色表示。
总共有 7 个没有被保卫的格子,所以我们返回 7 。

题目链接


题解:

点击查看代码
class Solution {// 右左下上private final static int[][] dir = {{0, 1}, {0, -1}, {1, 0}, {-1, 0}};public int countUnguarded(int m, int n, int[][] guards, int[][] walls) {int[][] all = new int[m][n];// 标记警卫格子,墙格子for (int[] g:guards){all[g[0]][g[1]] = 1;}for (int[] w:walls){all[w[0]][w[1]] = 1;}// 遍历警卫for (int[] g:guards){for (int[] d:dir){int dx= d[1] +g[1];int dy= d[0] +g[0];while (0<=dy && dy<m && 0<=dx && dx<n && all[dy][dx] != 1){all[dy][dx] = 2; // 被保卫dy += d[0];dx += d[1];}}}int res = 0;for (int[] row:all){for (int b:row){if (b==0){res++;}}}return res;}
} 
http://www.jsqmd.com/news/29161/

相关文章:

  • 完全背包内外层循环是否可以对调?
  • SQL新特性/SQL语言增强以及JSON新特性
  • CSP2025 游寄
  • MySQL性能分析(五)之status详解
  • 2025 年 11 月电动门厂家最新推荐,精准检测与稳定性能深度解析
  • 《密码系统设计》第九周预习
  • 2025年程序员兼职常用的10个平台推荐 - 教程
  • JavaScript笔记(1)
  • 回归 CSP-S2025游记
  • 使用netfilter_queue重定向IP数据包
  • 线性表、串、数组、广义表
  • 【赶紧收藏】7款Windows数据恢复神器!能解决99%的问题,手慢无!
  • 分类测试
  • 有哪些好用的媒体播放器
  • THUSC 2024 游记
  • 2025年10月学习机品牌推荐:AI精准学榜对比榜单
  • 2025年10月学习机品牌推荐:护眼大屏榜对比与品牌排名
  • JSOI 2024 游记
  • 2025年10月学习机品牌评价榜:五款主流机型横向对比指南
  • 2025年11月专业太空舱民宿品牌推荐排行:优质厂家对比评价
  • 2025年11月太空舱原材料推荐榜单:权威厂家综合评测与选择指南
  • 2025年11月太空舱民宿推荐榜单:权威对比与选择指南
  • 2025年11月太空舱民宿品牌排行:优质工厂生产资质与服务全解析
  • 2025年11月太空舱原材料推荐评价:有实力供应商排行与采购建议
  • 2025年11月太空舱原材料靠谱榜单:实力品牌横向对比报告
  • 2025年11月太空舱出口供应商评价:系统化排行专业厂家榜单
  • 2025年11月专业太空舱出口品牌排名:靠谱厂家多维度对比评测
  • 靖光通核心开发人员和您聊一聊程序员的心酸与成长
  • 2025年11月节油重卡品牌榜:供应厂家口碑与性能排名
  • 2025年11月节油重卡供应厂家推荐:口碑实力综合排名