USACO Section2.1 The Castle 解题报告
castle解题报告 —— icedream61 博客园(转载请注明出处)
------------------------------------------------------------------------------------------------------------------------------------------------
【题目】
有N×M的矩阵,边框都是实际存在的“墙”。如下图:
1 2 3 4 5 6 7
#############################
1 # | # | # | | #
#####---#####---#---#####---#
2 # # | # # # # #
#---#####---#####---#####---#
3 # | | # # # # #
#---#########---#####---#---#
4 # -># | | | | # #
#############################
上图就是N=4,M=7的一种情况,#表示墙,|表示没有墙。
没有墙的连通块,就被认为是一个房间。例如图中,(2,6)是一个面积为1的房间,(1,3)(1,4)(2,4)则是一个面积为3的房间。
现在请你打破一面墙,从而连通两个房间得到一个更大的房间。请你求出破出房间面积最大的情况,并给出下列输出。(例如图中就是打破箭头所指的墙)
【输入格式】
第一行两个数,M和N。
下面N行,每行M个数,依次是每个点四周墙的情况,各由一个数代表。这个数由四个数中的几个相加而成:
1: 左面有墙
2: 上面有墙
4: 右面有墙
8: 下面有墙
例如,11=8+2+1,表示此点除了右面,余下三面都有墙。
【输出格式】
第一行给出初始房间数。(例如图中有5个连通块,即5个房间)
第二行给出初始最大的房间。(图中便是(1,1)所在房间)
第三行给出打破一面墙所得的房间面积最大值。
第四行给出打破的是哪一面墙。(例如本题输出样例,便表示是(4,1)东面的墙)
注意:描述墙的方式,是用墙左面或下面的点的左边,加上墙相对点的方向('N'or'E')。如果有多面墙可供打破,那么优先选择最左面的,再优先最下面的,再优先墙相对点的方向为'N'的。
【数据范围】
1<=N,M<=50
【输入样例】
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
4 1 E
------------------------------------------------------------------------------------------------------------------------------------------------
【分析】
裸FloodFill。
好好画图,注意细节,需要存的大数组也就是每个点的信息和Fill出的每块的大小了。边是不能存的,计算一下会发现空间不够。
------------------------------------------------------------------------------------------------------------------------------------------------
【总结】
题目开始难起来了,要开始分析时空复杂度了。不能无脑刷了!
第一次,超空间了,没计算空间。
Edge定义成了邻接矩阵,2500²=6,250,000≈6M,由于是int,故6×4=24M,显然超过了USACO十几M内存的限制。
第二次,第七个点被卡主,原因是运行时间远超1s。
为了调试方便,觉得应该不会超时,就没删屏幕输出。
第三次,仍是第七个点,原因是运行时错误。
这数据是极限数据,N=M=50,所有位置都有墙。显然,应该是程序没判断好边界情况。
调试过程中,慢慢发现,问题出在超内存上!
墙满的时候,邻接表还不如邻接矩阵呢。。我竟然忘了这个!既然邻接表可能被占满,那显然比邻接矩阵更占空间啊……
仔细一想,我SB了……这题根本不用存边嘛……直接存点的信息就好了,一个裸的FloodFill愣是被我搞得如此复杂……
经过几次提交和修改,第七次,AC。
代码得改漂亮些……不能太难看了-.-
------------------------------------------------------------------------------------------------------------------------------------------------
【代码】
/*
ID: icedrea1
PROB: castle
LANG: C++
*/ #include <iostream>
#include <fstream>
using namespace std; int N,M,num[+*];
struct MapNode
{
int mark;
int wall;
}Node[+][+]; // Node[i][j]: i行j列的点 void Fill(int x,int y,int mark)
{
int wall=Node[x][y].wall;
Node[x][y].mark=mark; ++num[mark];
if(y> && (wall&)== && Node[x][y-].mark==) Fill(x,y-,mark); // 1 west (x,y-1)
if(x> && (wall&)== && Node[x-][y].mark==) Fill(x-,y,mark); // 2 north (x-1,y)
if(y<M && (wall&)== && Node[x][y+].mark==) Fill(x,y+,mark); // 4 east (x,y+1)
if(x<N && (wall&)== && Node[x+][y].mark==) Fill(x+,y,mark); // 8 south (x+1,y)
}
int FloodFill()
{
int mark,sum;
for(mark=,sum=;sum<N*M;++mark) // sum==N×M说明填满了,FlookFill结束
{
// 本次FlookFill的编号为mark
int x,y;
bool p=true;
for(int i=;i<=N&&p;++i)
for(int j=;j<=M&&p;++j)
if(Node[i][j].mark==) { x=i; y=j; p=false; }
// 从(x,y)开始本次FloodFill
Fill(x,y,mark); sum+=num[mark];
}
return mark-;
} int main()
{
ifstream in("castle.in");
ofstream out("castle.out"); in>>M>>N;
for(int i=;i<=N;++i)
for(int j=;j<=M;++j) in>>Node[i][j].wall; int cnt=FloodFill(),room=;
for(int i=;i<=cnt;++i)
if(num[i]>room) room=num[i]; int x,y,area=; char wall;
for(int j=,t;j<=M;++j)
for(int i=N;i>=;--i)
{
t=num[Node[i][j].mark]+num[Node[i-][j].mark];
if(i> && Node[i][j].mark!=Node[i-][j].mark && t>area) { area=t; x=i; y=j; wall='N'; }
t=num[Node[i][j].mark]+num[Node[i][j+].mark];
if(j<M && Node[i][j].mark!=Node[i][j+].mark && t>area) { area=t; x=i; y=j; wall='E'; }
} out<<cnt<<endl;
out<<room<<endl;
out<<area<<endl;
out<<x<<" "<<y<<" "<<wall<<endl; in.close();
out.close();
return ;
}
USACO Section2.1 The Castle 解题报告的更多相关文章
- USACO Section2.1 Healthy Holsteins 解题报告 【icedream61】
holstein解题报告 --------------------------------------------------------------------------------------- ...
- USACO Section2.2 Preface Numbering 解题报告 【icedream61】
preface解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.1 Hamming Codes 解题报告 【icedream61】
hamming解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.3 Controlling Companies 解题报告 【icedream61】
concom解题报告------------------------------------------------------------------------------------------ ...
- USACO Section2.3 Money Systems 解题报告 【icedream61】
money解题报告------------------------------------------------------------------------------------------- ...
- USACO Section2.3 Zero Sum 解题报告 【icedream61】
zerosum解题报告----------------------------------------------------------------------------------------- ...
- USACO Section2.3 Cow Pedigrees 解题报告 【icedream61】
nocows解题报告------------------------------------------------------------------------------------------ ...
- USACO Section2.3 Longest Prefix 解题报告 【icedream61】
prefix解题报告------------------------------------------------------------------------------------------ ...
- USACO Section2.2 Party Lamps 解题报告 【icedream61】
lamps解题报告------------------------------------------------------------------------------------------- ...
随机推荐
- IOS 数据加密总结(及MD5加密)
数据安全总结 1.网络数据加密1> 加密对象:隐私数据,比如密码.银行信息2> 加密方案* 提交隐私数据,必须用POST请求* 使用加密算法对隐私数据进行加密,比如MD53> 加密增 ...
- 使用browsermob代理出现错误java.lang.NoClassDefFoundError: org/littleshoot/proxy/HttpFiltersSource
使用browsermob代理做埋点数据,maven配置的包如下 <dependency> <groupId>net.lightbody.bmp</groupId> ...
- spring教程(一):简单实现(转)
转:https://www.cnblogs.com/Lemon-i/p/8398263.html 一.概念介绍 1. 一站式框架:管理项目中的对象.spring框架性质是容器(对象容器) 2. 核心 ...
- mayan 游戏真是毒瘤
如题 真坑呀!!! 可算过了 我率先达到了氧气富有化 先是改变时没有fall.40分 然后是fall函数写慢了 tle 50分 . 上代码 #include<cstdio> #includ ...
- BZOJ1202: [HNOI2005]狡猾的商人(带权并查集)
Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4577 Solved: 2249[Submit][Status][Discuss] Descript ...
- Spring Cloud 入门 Consul-Client服务提供
前面介绍了 Rureka Client服务提供, 只需要改pom.xml部分内容 1.pom.xml <?xml version="1.0" encoding="U ...
- RPC框架基础概念理解以及使用初体验
RPC:Remote Procedure Call(远程服务调用) RPC是做什么的 通过RPC框架机器A某个进程可以通过网络调用机器B上的进程方法,就像在本地上调用一样. RPC可以基于HTTP或者 ...
- 如何解决mysql中读取含表情符号的内容无法识别的问题
当内容中包含有表情符号的时候,写入mysql时一般会设置字段或者表的charset为utf8mb4的形式: ) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicod ...
- FreeBSD--如何最有效率的安装软件
Freebsd 下如何最有效率的安装软件 From <https://www.cnblogs.com/apexchu/p/4131821.html> FreeBSD的默认下载工具是fetc ...
- Centos7安装Mysql5.7并修改初始密码
1.CentOS 的yum源中没有mysql,需要到mysql的官网下载yum repo配置文件. wget https://dev.mysql.com/get/mysql57-community-r ...