#352. [CZOI2011 G] 房间问题

[CZOI2011 G] 房间问题

题目描述

从玉龙雪山下来后,同学们来到了传说中的大理皇宫,看着皇宫外的平面图,大家都想知道大理皇宫到底有多少个房间?其中最大的房间有多大?由于大理皇宫非常大,同学们在雪山上玩得太累了,都点不清房间的数目了,这时聪明的小s同学想到了一个好主意,她说我们把平面图拍下来带回去让小朋友们编个程序数吧!这个主意得到了大家的一致同意,现在你的任务是帮助小 s 去数一数房间的数目和最大的房间的大小。而且小 s 在回来的飞机上还想出了一个更难的问题,她想拆掉一堵墙来制造一个更大的房间,如果你能解决这个难题,小 s 将会额外给你一件奖品。皇宫的平面图被分为 M×NM \times N 个小正方形,每个这样的小正方形有 0044 堵墙。皇宫在它的外部边缘总是有墙壁的,好用来遮挡风雨。在下面的例子中标注了一个皇宫的平面图,为了让大家能更好地理解本问题,我们用两种方法表示皇宫的平面图,第一种是用表格来表示,其中粗线表示墙壁,细线表示没有墙壁。第二种用文本表示。

样例中皇宫大小为 7×47 \times 4

我们定义一个“房间”是指平面图连接在一起的中间没有墙壁隔开的“小正方形”的总体。这个平面图包含 55 个房间。它们的大小分别是 9,7,3,1,89,7,3,1,8。把那堵用箭头标记的墙壁拆掉后合并出的新房间将是拆掉一堵墙所能产生的最大房间,这个房间由 1616 个小正方形组成。皇宫至少有两个房间并且总是有一堵墙壁可供拆掉

输入格式

皇宫平面图用一个二维数组来储存,每个数描述一个小正方形,共有N行数据,每行有M个数。输入顺序符合上例的编号方式。每个小正方形的墙的特征用整数 PP 来描述(0P150 \le P \le 15)。PP 是下面 44 个可能取到的数字之和:

11: 在小正方形的西面有墙,平面图中西面即左边

22: 在小正方形的北面有墙,平面图中北面即上边

44: 在小正方形的东面有墙,平面图中东面即右边

88: 在小正方形的南面有墙,平面图中南面即下边

内部的墙壁会被定义两次,小正方形 (1,1)(1,1) 南面的墙也同时是小正方形 (2,1)(2,1) 北面的墙。小正方形 (1,1)(1,1) 的南面、北面和西面都有墙,所以它的特征数 P=8+2+1=11P=8+2+1=11

11 行有两个用空格隔开的整数 MMNN

22N+1N+1 行: 每行 MM 个用空格隔开的整数,表示该行小正方形的墙的特征。

输出格式

第一行包含一个整数表示皇宫的房间数目。

第二行包含一个整数表示最大的房间的大小。 第三行包含一个整数表示拆掉一堵墙能得到的最大的房间的大小。

7 4
11 6 11 6 3 10 6
7 9 6 13 5 15 5
1 10 12 7 13 7 5
13 11 10 8 10 12 13
5
9
16

数据范围

40%40\% 的数据满足 1M,N501 \leq M,N\leq50

100%100\% 的数据满足 1M,N10001 \leq M,N \leq 1000