mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-11 02:58:13 +08:00
43 lines
2.5 KiB
HTML
43 lines
2.5 KiB
HTML
<p>给你两个整数 <code>m</code> 和 <code>n</code> 表示一个下标从<strong> 0</strong> 开始的 <code>m x n</code> 网格图。同时给你两个二维整数数组 <code>guards</code> 和 <code>walls</code> ,其中 <code>guards[i] = [row<sub>i</sub>, col<sub>i</sub>]</code> 且 <code>walls[j] = [row<sub>j</sub>, col<sub>j</sub>]</code> ,分别表示第 <code>i</code> 个警卫和第 <code>j</code> 座墙所在的位置。</p>
|
||
|
||
<p>一个警卫能看到 4 个坐标轴方向(即东、南、西、北)的 <strong>所有</strong> 格子,除非他们被一座墙或者另外一个警卫 <strong>挡住</strong> 了视线。如果一个格子能被 <strong>至少</strong> 一个警卫看到,那么我们说这个格子被 <strong>保卫</strong> 了。</p>
|
||
|
||
<p>请你返回空格子中,有多少个格子是 <strong>没被保卫</strong> 的。</p>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>示例 1:</strong></p>
|
||
|
||
<p><img alt="" src="https://assets.leetcode.com/uploads/2022/03/10/example1drawio2.png" style="width: 300px; height: 204px;"></p>
|
||
|
||
<pre><b>输入:</b>m = 4, n = 6, guards = [[0,0],[1,1],[2,3]], walls = [[0,1],[2,2],[1,4]]
|
||
<b>输出:</b>7
|
||
<strong>解释:</strong>上图中,被保卫和没有被保卫的格子分别用红色和绿色表示。
|
||
总共有 7 个没有被保卫的格子,所以我们返回 7 。
|
||
</pre>
|
||
|
||
<p><strong>示例 2:</strong></p>
|
||
|
||
<p><img alt="" src="https://assets.leetcode.com/uploads/2022/03/10/example2drawio.png" style="width: 200px; height: 201px;"></p>
|
||
|
||
<pre><b>输入:</b>m = 3, n = 3, guards = [[1,1]], walls = [[0,1],[1,0],[2,1],[1,2]]
|
||
<b>输出:</b>4
|
||
<b>解释:</b>上图中,没有被保卫的格子用绿色表示。
|
||
总共有 4 个没有被保卫的格子,所以我们返回 4 。
|
||
</pre>
|
||
|
||
<p> </p>
|
||
|
||
<p><strong>提示:</strong></p>
|
||
|
||
<ul>
|
||
<li><code>1 <= m, n <= 10<sup>5</sup></code></li>
|
||
<li><code>2 <= m * n <= 10<sup>5</sup></code></li>
|
||
<li><code>1 <= guards.length, walls.length <= 5 * 10<sup>4</sup></code></li>
|
||
<li><code>2 <= guards.length + walls.length <= m * n</code></li>
|
||
<li><code>guards[i].length == walls[j].length == 2</code></li>
|
||
<li><code>0 <= row<sub>i</sub>, row<sub>j</sub> < m</code></li>
|
||
<li><code>0 <= col<sub>i</sub>, col<sub>j</sub> < n</code></li>
|
||
<li><code>guards</code> 和 <code>walls</code> 中所有位置 <strong>互不相同</strong> 。</li>
|
||
</ul>
|