每日一题:Leet 2257. 统计网格图中没有被保卫的格子数
给你两个整数m和n表示一个下标从 0 开始的m x n网格图。同时给你两个二维整数数组guards和walls,其中guards = 且 walls = ,分别表示第i个警卫和第j座墙所在的位置。一个警卫能看到 4 个坐标轴方向(即东、南、西、北)的所有格子,除非他们被一座墙或者另外一个警卫挡住了视线。如果一个格子能被至少一个警卫看到,那么我们说这个格子被保卫了。
请你返回空格子中,有多少个格子是没被保卫 的。
示例:
输入:m = 4, n = 6, guards = [,,], walls = [,,]
输出: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; // 标记警卫格子,墙格子 for (int[] g:guards){ all]] = 1; } for (int[] w:walls){ all]] = 1; } // 遍历警卫 for (int[] g:guards){ for (int[] d:dir){ int dx= d +g; int dy= d +g; while (0 yyds。多谢分享 收藏一下 不知道什么时候能用到 用心讨论,共获提升! 懂技术并乐意极积无私分享的人越来越少。珍惜 谢谢分享,辛苦了 分享、互助 让互联网精神温暖你我 这个好,看起来很实用 热心回复! 这个好,看起来很实用 感谢,下载保存了 东西不错很实用谢谢分享 这个有用。 这个好,看起来很实用 谢谢分享,辛苦了 这个好,看起来很实用 很好很强大我过来先占个楼 待编辑 这个好,看起来很实用 过来提前占个楼
页:
[1]