- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
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
- 2024-2025学年贵州省遵义市求是高级中学高三下学期第二次模拟考试(语文试题文)试题含解析.doc
- 2024-2025学年广东省潮州市重点中学高三第二学期3月高考诊断性测试语文试题含解析.doc
- 2024-2025学年甘肃省陇东中学高三下学期适应性考试语文试题含解析.doc
- 2024-2025学年广东省“十二校”高三下学期期中考试(语文试题理)试题含解析.doc
- 2024-2025学年甘肃省武夷市民勤县第一中学高三下学期期末模拟卷(一)语文试题含解析.doc
- 2024-2025学年广东省深圳市龙文教育高三5月月考(语文试题理)试题含解析.doc
- 2024-2025学年贵州省铜仁一中高三第二学期期末考试语文试题试卷含解析.doc
- 2024-2025学年广州顺德区高三第一次诊断性考试语文试题试卷含解析.doc
- 2024-2025学年贵阳市高考二轮语文试题原创押题密卷(一)含解析.doc
- 2024-2025学年河北省保定市曲阳县一中高三教学质量检测试题(一模)语文试题试卷含解析.doc
文档评论(0)