CF2161B Make Connected
题目描述
给你一个 $n \times n$ 的网格,其中一些格子被涂成黑色,其余格子为白色。你可以将部分白色格子涂黑,使得最终满足以下条件:
1. 至少存在一个黑色格子。
2. 所有黑色格子是正交连通的,即从任意一个黑色格子出发,只经过若干条水平或垂直边且只经过黑色格子,可以到达任意另一个黑色格子。你不能直接通过格子的对角线连通。
3. 不存在三个垂直或水平连续排列的黑色格子。
你不能将黑色格子涂白。
请判断是否可以通过涂黑一些白色格子,使得上述条件均得到满足。
输入格式
每个测试点包含多组测试用例。第一行包含一个整数 $t$($1 \leq t \leq 1000$),表示测试用例的数量。
每组测试用例的第一行包含一个整数 $n$($1 \leq n \leq 100$),表示网格的大小。
接下来的 $n$ 行中,每行包含 $n$ 个字符,描述网格的状态。每个字符代表一个格子:
- `.` 表示白色格子;
- `#` 表示黑色格子。
保证所有测试用例中 $n$ 的总和不超过 $2000$。
输出格式
对于每个测试用例,如果存在一种方法可以将部分白色格子涂黑,使得所有条件都满足,则输出 “YES”;否则输出 “NO”。
你可以以任意大小写输出答案。例如,"yEs"、"yes"、"Yes" 和 "YES" 都被视为正确答案。
说明/提示
在第一个测试用例中,初始没有黑色格子,因此必须涂黑至少一个格子。
在第二个和第三个测试用例中,初始网格已经满足所有条件。
在第四个测试用例中,其中一种可行的方案为:
```
##.
.##
..#
```
在第五个测试用例中,初始网格已经存在三连黑格,违反条件三,因此无解。
在第六个测试用例中,可以证明无法在不违反三个连续黑格条件下,使所有黑格连通。
由 ChatGPT 5 翻译