#USACO1021. 2.1.1 城堡 The Castle

2.1.1 城堡 The Castle

题目背景

我们憨厚的 USACO 主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特别的礼物:一张“幸运爱尔兰”(一种彩票)。结果这张彩票让他获得了这次比赛唯一的奖品——坐落于爱尔兰郊外的一座梦幻般的城堡!

题目描述

喜欢吹嘘的农夫约翰立刻回到有着吹嘘传统的威斯康辛老家开始吹嘘了, 农夫约翰想要告诉他的奶牛们关于他城堡的一切。他需要做一些吹嘘前的准备工作:比如说知道城堡有多少个房间,每个房间有多大。

另外,农夫约翰想要把一面单独的墙(指两个单位间的墙)拆掉以形成一个更大的房间。 你的工作就是帮农夫约翰做以上的准备,算出房间数与房间的大小。

城堡的平面图被划分成 n×mn \times m 个正方形的单位,一个这样的单位可以有 040 \sim 4 面墙环绕。城堡周围一定有外墙环绕以遮风挡雨。(就是说平面图的四周一定是墙。)

请仔细研究下面这个有注解的城堡平面图:

友情提示,这个城堡的平面图是 4×74 \times 7 个单位的。一个“房间”的是平面图中一个由 #-| 围成的格子(就是图里面的那一个个的格子)。比如说这个样例就有 55 个房间。(大小分别为 9,7,3,1,89,7,3,1,8 个单位(排名不分先后))

移去箭头所指的那面墙,可以使 22 个房间合为一个新房间,且比移去其他墙所形成的房间都大。

城堡保证至少有 22 个房间,而且一定有一面墙可以被移走。

输入格式

第一行两个正整数 m,nm,n,表示城堡有 nnmm 列。

每一个单位的数字告诉我们这个单位的东西南北是否有墙存在。每个数字是由以下四个整数中的任意个加起来的。

11: 在西面有墙

22: 在北面有墙

44: 在东面有墙

88: 在南面有墙

城堡内部的墙会被规定两次。比如说 (1,1)(1,1) 南面的墙,亦会被标记为 (2,1)(2,1) 北面的墙。

输出格式

输出包含如下四行:

第一行:城堡的房间数目。

第二行:最大的房间的大小

第三行:移除一面墙能得到的最大的房间的大小

第四行:移除哪面墙可以得到面积最大的新房间。

选择最佳的墙来推倒。有多解时选最靠西的,仍然有多解时选最靠南的。同一格子北边的墙比东边的墙更优先。

用该墙的南邻单位的北墙或西邻单位的东墙来表示这面墙,方法是输出邻近单位的行数、列数和墙的方位( N(北)或者 E(东))。

样例 #1

样例输入 #1

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

样例输出 #1

5
9
16
4 1 E

提示

【数据范围】
对于 100%100\% 的数据,1n,m501\le n,m \le 50

USACO 2.1

翻译来自NOCOW