P1457 城堡 The Castle
轻度中毒
原题 :The Castle
以下为题解部分:明明辣么简单的一道题,硬是搞了1.5h,WTF?以下列出本题的一些要点。
- 搜索(DFS)嘛,染色嘛,统计大小嘛,很容易想,也很更易处理。
- 接下来就只需要枚举墙,得出最大值了。好像很简单的样子QAQ——but №!我™就是在这里折腾了一个小时(可能是我太菜了)。
- 蒟蒻统计的思路是:北墙(-1,0)与东墙(0,+1)分开枚举,得到各自的最优解,然后再比较这两个解,输出更好的那个(捂脸)。
详细见丑*代码:
#include <cstdio> #include <cstring> #include <iostream> #include <algorithm> main() {} const int fx[]= {0,-1,0,1};//W,N,E,S const int fy[]= {-1,0,1,0}; int n,m,id[51][51],a[51][51],tot,room[50*50+1]; void clor(int x,int y,int c) { id[x][y]=c; room[c]++;//面积 for(int i=0,nx,ny; i<4; i++) if(!(a[x][y]&(1<<i))) {//美丽的二进制解析 nx=x+fx[i],ny=y+fy[i]; if(nx>0&&ny>0&&nx<=n&&ny<=m&&!id[nx][ny]) clor(nx,ny,c); } } int entry() { scanf("%d%d",&m,&n); for(int i=1; i<=n; i++) { for(int j=1; j<=m; j++) scanf("%d",&a[i][j]); } for(int i=1; i<=n; i++) {//染色 for(int j=1; j<=m; j++) if(!id[i][j]) clor(i,j,++tot); } int maxn=*std::max_element(room+1,room+tot+1); printf("%d\n""%d\n",tot,maxn); int ans1=maxn,ans2=maxn; int x1=n,y1=0,x2=n,y2=0; for(int i=1; i<=n; i++) for(int j=1; j<=m; j++) { if((a[i][j]&2)&&id[i][j]!=id[i-1][j]&&ans1<=room[id[i][j]]+room[id[i-1][j]]) { if(ans1!=room[id[i][j]]+room[id[i-1][j]]) x1=i,y1=j; else if(j<y1) y1=j,x1=i;//West else if(j==y1 && i>x1) x1=i;//South ans1=room[id[i][j]]+room[id[i-1][j]]; }//北墙 if((a[i][j]&4)&&id[i][j]!=id[i][j+1]&&ans2<=room[id[i][j]]+room[id[i][j+1]]) { if(ans2!=room[id[i][j]]+room[id[i][j+1]]) x2=i,y2=j; else if(j<y2) y2=j,x2=i;//West else if(j==y2 && i>x2) x2=i;//South ans2=room[id[i][j]]+room[id[i][j+1]]; }//东墙 } if(ans1>ans2) printf("%d\n%d %d N\n",ans1,x1,y1); else if(ans1<ans2) printf("%d\n%d %d E\n",ans2,x2,y2);//maxmize result else if(y1<y2) printf("%d\n%d %d N\n",ans1,x1,y1); else if(y1>y2) printf("%d\n%d %d E\n",ans2,x2,y2);//west else if(x1>x2) printf("%d\n%d %d N\n",ans1,x1,y1); else if(x1<x2) printf("%d\n%d %d E\n",ans2,x2,y2);//south else printf("%d\n%d %d N\n",ans1,x1,y1); } int aptal=entry();
P1457 城堡 The Castle的更多相关文章
- 洛谷P1457 城堡 The Castle
P1457 城堡 The Castle 137通过 279提交 题目提供者该用户不存在 标签USACO 难度提高+/省选- 提交 讨论 题解 最新讨论 暂时没有讨论 题目描述 我们憨厚的USACO ...
- 洛谷 P1457 城堡 The Castle 解题报告
P1457 城堡 The Castle 题目描述 我们憨厚的USACO主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特别的礼物:一张"幸运爱尔兰" ...
- 洛谷 P1457 城堡 The Castle
P1457 城堡 The Castle 题目描述 我们憨厚的USACO主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特别的礼物:一张“幸运爱尔兰”(一种彩票).结果这 ...
- 洛谷—— P1457 城堡 The Castle
https://www.luogu.org/problem/show?pid=1457 题目描述 我们憨厚的USACO主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特 ...
- P1457 城堡 The Castle 位运算+BFS+思维(难题,好题)
题目描述 我们憨厚的USACO主人公农夫约翰(Farmer John)以无法想象的运气,在他生日那天收到了一份特别的礼物:一张"幸运爱尔兰"(一种彩票).结果这张彩票让他获得了这次 ...
- 题解 洛谷P1457 【城堡 The Castle】
这道题,看似很烦,无从下手,但其实只要用位运算和联通快就能水过了呀. 首先,输入:似乎大意是把一个数拆成二进数的相加,分别表示\((i,j)\)东南西北是否有墙.\(1\)表示西,\(2\)表示北,\ ...
- 题解 P1457 【城堡 The Castle】
来讨论区大摇大摆地逛了一圈后,我发现竟然大家的代码 都很长 然而代码真的要写那么长吗 首先,来分析问题,1,2,4,8,这些数显然是有特点的,也许你已经想到了没错,它们都是2的次方数. 1是2的0次方 ...
- [USACO Section 2.1]城堡 The Castle (搜索)
题目链接 Solution 比较恶心的搜索,思路很简单,直接广搜找联通块即可. 但是细节很多,要注意的地方很多.所以直接看代码吧... Code #include<bits/stdc++.h&g ...
- Luogu USACO Training 刷水记录
开个坑记录一下刷USACO的Training的记录 可能会随时弃坑 只有代码和做法简述 可能没有做法简述 [USACO1.1]你的飞碟在这儿Your Ride Is He… 模拟,细节已忘 #incl ...
随机推荐
- commonjs模块和es6模块的区别
commonjs模块与es6模块的区别 到目前为止,已经实习了3个月的时间了.最近在面试,在面试题里面有题目涉及到模块循环加载的知识.趁着这个机会,将commonjs模块与es6模块之间一些重要的的区 ...
- 设置QT应用程序图标方法(Windows下)
学习笔记,言简意赅. 1- 新建文本文件,编辑输入 IDI_ICON1 ICON DISCARDABLE "./image/WindowIco.ico" 注意: ...
- 继承“HibernateDaoSupport”后,报“The hierarchy of the type AccoutDaoImpl is inconsistent”的解决方案
解决办法: 今天写了一段很简单的代码,Eclipse竟然报错 import org.springframework.jdbc.core.support.JdbcDaoSupport; import c ...
- asp.net C# 实现微信服务器配置
微信服务器配置接收页面示例代码 /// <summary> /// 微信的Token /// </summary> const string Token = "Tok ...
- 损失函数&经验函数
损失函数:度量模型一次预测的好坏 经验函数:度量模型平均意义下的预测好坏 输出预测值F(x)与实际值Y可能不一致也可能一致,损失函数(Loss function)可以度量一次预测,记作L(Y,F(x) ...
- USACO2004 Open提交作业(区间DP)
Description 贝西在哞哞大学选修了C门课,她要把这些课的作业交给老师,然后去车站和同学们一 起回家.老师们在办公室里,办公室要等他们下课后才开,第i门课的办公室在Ti时刻后开放. 所有的办公 ...
- 突发小事件,USB接口问题
昨天遇到的突发事件,突然USB接口全部瘫了,键盘鼠标全部不能用,换到别人电脑上可以,吓尿了,以为本子主板挂了,但是发现插U盘竟然可以识别而且可以打开,感觉可能是静电问题,果然,彻底关机,拔掉电池,然后 ...
- PHP的Session机制
客户端浏览器和服务器之间通信使用的http协议是一种无状态的协议,在它看来,客户端发起的每个请求都是独立.没有关联的.然而,在实际的Web应用开发中,服务器却经常需要根据用户以往的一些状态或数据对请求 ...
- 2017上海QCon之旅总结(中)
本来这个公众号的交流消息中间件相关的技术的.上周去上海参加了QCon,第一次参加这样的技术会议,感受挺多的,所以整理一下自己的一些想法接公众号和大家交流一下. 三天的内容还挺多的,原计划分上下两篇总结 ...
- linux学习(五)系统目录结构,ls命令,文件类型,alias
一.系统目录结构 在我们的根目录下,有这样一些文件夹 /bin /sbin /usr/bin /usr/sbin /sbin一般都是root用户用的 /boot 系统启动相关的,grup就放在这里,这 ...