3035. 次大黑区域

单点时限: 2.0 sec

内存限制: 256 MB

二值图像是由黑白两种像素组成的矩形点阵,图像识别的一个操作是求出图像中次大 (第二大) 黑区域的面积。请设计一个程序完成二值图像的这个操作。黑区域由若干黑像素组成,一个黑区域中的每个黑像素至少与该区域中的另一个黑像素相邻,规定一个像素仅与其上、下、左、右的像素相邻。两个不同的黑区域没有相邻的像素。一个黑区域的面积是其所包含的黑像素的个数。

输入格式

1 行:一个整数 T (1T10) 为问题数。

接下来共 T 组测试数据,每组测试数据的第一行含两个整数 n,m (1n,m100),分别表示二值图像的行数与列数,后面紧跟着 n 行,每行含 m 个整数 01,其中第 i 行表示图像的第 i 行的 m 个像素,0 表示白像素,1 表示黑像素。同一行的相邻两个整数之间用一个空格隔开。

输出格式

对于每个问题,输出一行问题的编号(0 开始编号,格式:case #0: 等)。

然后对应每组测试数据,在一行中输出一个整数,表示相应的图像中次大(第二大)黑区域的面积。如果第二大面积的黑区域不存在时,则输出 0

样例

Input
3
2 3
1 1 0
0 1 1
4 5
0 1 1 0 1
0 0 0 1 0
0 1 1 1 0
0 1 0 0 0
5 6
1 1 0 0 1 1
1 1 0 1 1 0
0 0 1 0 0 1
1 1 0 1 0 1
0 1 0 1 1 0
Output
case #0:
0
case #1:
2
case #2:
3

提示

第一组测试数据:

1 1 0
0 1 1

在图像中只能找到 1 个黑区域,面积为 4,因此次大(第二大)黑区域的面积为 0
第三组测试数据:

1 1 0 0 1 1
1 1 0 1 1 0
0 0 1 0 0 1
1 1 0 1 0 1
0 1 0 1 1 0

在图像中能找到 6 个黑区域,它们的面积分别为 4,4,3,3,2,1,次大(第二大)黑区域的面积为 3

363 人解决,398 人已尝试。

454 份提交通过,共有 1165 份提交。

1.7 EMB 奖励。

创建: 10 年,10 月前.

修改: 6 年,8 月前.

最后提交: 1 天,1 小时前.

来源: 2014年编程实践课程第三次上机考试