一、题目描述
2XXX年,人类通过对火星的大气进行宜居改造分析,使得火星已在理论上具备人类宜居的条件;
由于技术原因,无法一次性将火星大气全部改造,只能通过局部处理形式;
假设将火星待改造的区域为row *column的网格,每个网格有3个值,宜居区、可改造区、死亡区,使用YES、NO、NA代替,YES表示该网格已经完成大气改造,NO表示该网格未进行改造,后期可进行改造,NA表示死亡区,不作为判断是否改造完的宜居,无法穿过;
初始化下,该区域可能存在多个宜居区,并目每个宜居区能同时在每个大阳日单位向上下左右四个方向的相邻格子进行扩散,自动将4个方向相邻的真空区改造成宜居区;
请计算这个待改造区域的网格中,可改造区是否能全部成宜居区,如果可以,则返回改造的大阳日天教,不可以则返回-1
二、输入描述
输入row * column个网格数据,每个网格值枚举值如下: YES,NO,NA;
三、输出描述
可改造区是否能全部变成宜居区,如果可以,则返回改造的太阳日天数,不可以则返回-1。
四、测试用例
测试用例1
1、输入
3
YES NO NO
NO NO NO
NO NO YES
2、输出
2
本文介绍了华为在线测评(OD)中的一道关于图的多源广度优先搜索(BFS)问题。题目涉及火星宜居改造,要求计算将所有可改造区转变为宜居区所需的太阳日数。解题思路包括读取输入、遍历图并进行BFS改造,最后给出Java算法源码和实例效果展示。
订阅专栏 解锁全文





