- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
UVaOJ 705 - Slash Maze 解题报告
UVaOJ 705 – Slash Maze
——by A Code Rabbit
Description
输入一张迷宫图,全部由 /、\ 组成。
这样,迷宫就变成一个斜线迷宫。
因为输入全为 / 、\ ,因此,这个迷宫
将由全部宽度为 1 的路径组成。
要求输出迷宫中有几个回环,即封闭的
路径有几条,其中最长的有多长。
Types
Date Structure :: Graphs
Analysis
经典的斜线迷宫题。
可用 FloodFill 解决。
首先知道,没有封闭的路径,必然将通往图的外面。
所以只要从图的边界开始 FloodFill ,把不满足条件的排除后。
再对每一个点去 FloodFill 即可求出所要的解。
而对于斜线的处理,有三种方法:
1. 九分法:将所有的格子都扩大成 9 * 9 的格子,例如
‘/’ 就会变成
#
#
#
然后只要用普通的 FloodFill 对每格上下左右四个方向的 DFS 就可以。
2. 四分法:将所有的格子扩大成 4 * 4 的格子,例如
‘/’ 就会变成
#
#
然后依然是对每个格子向八个方向 FloodFill ,但是要注意,在 2 * 2 格子中的某点向周围 Flood 的时
候,只能到达上下左右的 2 * 格子。
反之如果 FloodFill 后依然在原先的 2 * 格子,或者对角线方向的 2 * 2 格子的,将会是穿过了 / 的
非法情况,需要排除掉。
3. 光线反射法:模拟一条光线在迷宫中照射,继续看图:
对于每个格子,光线可能从四个方向
射进来。
1
在 FloodFill 的时候,判断光线来的方向,找到下一个 FloodFill 的格子即可。
三种方法,第一种较为简单,但是要将原图长宽各扩大三倍,得到一张原图九倍大的新图。
而第二种方法,只要将原图扩大四倍,但是要判断要 FloodFill 的格子是否可以 FloodFill。
而第三种方法,较为复杂,对光线进来的四个方向都要判断反射出去的方向,可以用一个 enum 配合
const 数组来映射,好处就是不用扩大原图,时间复杂度相对前两种,常数较低。
Solution
1. 九分法
// UVaOJ 705
// Slash Maze
// by A Code Rabbit
#include cstdio
struct Change {
int x;
int y;
};
Change CHANGE[] = {
{-1, 0},
{ 0, -1}, { 0, 1},
{ 1, 0},
};
const int LIMITS_W = 1000;
const int LIMITS_H = 1000;
int num_case = 0;
char maze[LIMITS_H][LIMITS_W];
int w, h;
int w_maze, h_maze;
void EnlargeAndSave(int x, int y, char ch);
int FloodFill(int x, int y);
int main() {
while (scanf(%d%d, w, h)) {
getchar();
// Exit.
if (!w !h) {
break;
}
// Inputs.
for (int i = 0; i h; ++i) {
for (int j = 0; j w; ++j) {
EnlargeAndSave(i, j, getchar());
}
getchar();
}
w_maze = w * 3;
h_maze = h * 3;
您可能关注的文档
- 第05章 垄断与竞争.ppt
- DS_2010_73数据结构课件.pdf
- EDS-T-4302:1999 DURABILITY TEST OF ASSIST GRIP.pdf
- Effect of smoking on the gingival capillary density:assessment of gingival capillary density.pdf
- FM25L16B铁电存储SPI操作例程.pdf
- GeorgeD_Spindler与文化教育_省略_述弱势群体或少数民族在学业上遭.pdf
- 电路中各点电位的分析和计算.ppt
- Int. Conf. on Data Warehousing and Knowledge Discovery DaWaK ’99 Implementation of Multidi.pdf
- Linux下S3C2440微控制器的CAN驱动设计与实现.pdf
- MAX113CAG+;MAX117CAI+;MAX117EAI+;MAX117CAI+T;MAX117CPI+;中文规格书,Datasheet资料.pdf
- 场地脚手架工程施工方案(3篇).docx
- 2024年浙江省丽水市松阳县玉岩镇招聘社区工作者真题及参考答案详解一套.docx
- 2024年河南省郑州市惠济区古荥镇招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市淳安县文昌镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省台州市三门县小雄镇招聘社区工作者真题带答案详解.docx
- 2024年浙江省宁波市余姚市河姆渡镇招聘社区工作者真题及完整答案详解1套.docx
- 2024年浙江省丽水市景宁畲族自治县雁溪乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省杭州市临安市板桥乡招聘社区工作者真题及答案详解一套.docx
- 2024年湖北省宜昌市点军区土城乡招聘社区工作者真题及答案详解一套.docx
- 2024年浙江省台州市路桥区桐屿街道招聘社区工作者真题附答案详解.docx
最近下载
- 新人教版高中物理必修第一册学案:2.2匀变速直线运动的速度与时间的关系.doc VIP
- 新生儿低氧血症的常规管理PPT课件.pptx VIP
- 高考英语句子成分及句子基本结构(共32张PPT).pptx VIP
- 药物成瘾教案.ppt VIP
- 广东省广州市五校2022-2023学年高一下学期期末联考物理试卷及参考答案.pdf VIP
- 海砂混凝土工程施工方案(3篇).docx VIP
- 2024年湖北省执业药师继续教育处方审核—中西药联合用药(3)答案.docx VIP
- 冷热疗法的效应.ppt VIP
- 卫生院优质服务基层行创建资料(4.8.1 信息公开).docx VIP
- 呼吸衰竭病人护理查房.pptx VIP
文档评论(0)