#aBC351D. [ABC351D] Grid and Magnet
[ABC351D] Grid and Magnet
AT_abc351_d [ABC351D] Grid and Magnet
题目描述
有一个 行 列的格子,其中有若干个(也可能为 个)格子上放置了磁铁。
格子的状态由 个长度为 的字符串 表示, 的第 个字符为 # 时,表示从上往下第 行、从左往右第 列的格子上放置了磁铁,为 . 时表示该格子上没有放置任何东西。
高桥君穿着铁制盔甲,在某个格子时可以按如下方式移动:
- 如果当前格子的上下左右相邻的任意一个格子上放置了磁铁,则无法移动到任何地方。
- 否则,可以选择上下左右相邻的任意一个格子并移动到该格子。
但不能移动到格子外面。
对于没有放置磁铁的每个格子,定义该格子的自由度为“最初高桥君在该格子时,从该格子出发通过多次移动能够到达的格子的数量”。
请你求出所有没有放置磁铁的格子中,自由度的最大值。
需要注意的是,在自由度的定义中,“能够通过多次移动到达的格子”指的是,从最初所在的格子出发,通过若干次(也可以为 次)移动能够到达的格子,不要求存在一种移动方式能够遍历所有这些格子。特别地,每个没有放置磁铁的格子本身总是包含在“能够到达的格子”之中。
输入格式
输入按以下格式从标准输入读入。
输出格式
请输出所有没有放置磁铁的格子中,自由度的最大值。
输入输出样例 #1
输入 #1
3 5
.#...
.....
.#..#
输出 #1
9
输入输出样例 #2
输入 #2
3 3
..#
#..
..#
输出 #2
1
说明/提示
限制条件
- 为整数
- 是仅由
.和#组成的长度为 的字符串 - 至少存在一个没有放置磁铁的格子
样例解释 1
用 表示从上往下第 行、从左往右第 列的格子。
当高桥君最初在 时,移动的例子有如下几种:
因此,包括途中经过的格子在内,高桥君从 至少可以到达 个格子。
另一方面,无法到达其他格子,因此 的自由度为 。
这是所有没有放置磁铁的格子中自由度的最大值,因此输出 。
样例解释 2
对于没有放置磁铁的任意格子,其上下左右相邻的格子中至少有一个放置了磁铁。
因此,从没有放置磁铁的任意格子都无法移动,自由度为 。
所以输出 。
由 ChatGPT 4.1 翻译