Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 4046 | Accepted: 1838 |
Description
One popular maze-walking strategy guarantees that the visitor will eventually find the exit. Simply choose either the right or left wall, and follow it. Of course, there's no guarantee which strategy (left or right) will be better, and the path taken is seldom the most efficient. (It also doesn't work on mazes with exits that are not on the edge; those types of mazes are not represented in this problem.)
As the proprieter of a cornfield that is about to be converted into a maze, you'd like to have a computer program that can determine the left and right-hand paths along with the shortest path so that you can figure out which layout has the best chance of confounding visitors.
Input
Exactly one 'S' and one 'E' will be present in the maze, and they will always be located along one of the maze edges and never in a corner. The maze will be fully enclosed by walls ('#'), with the only openings being the 'S' and 'E'. The 'S' and 'E' will also be separated by at least one wall ('#').
You may assume that the maze exit is always reachable from the start point.
Output
Sample Input
2 8 8 ######## #......# #.####.# #.####.# #.####.# #.####.# #...#..# #S#E#### 9 5 ######### #.#.#.#.# S.......E #.#.#.#.# #########
Sample Output
37 5 5 17 17 9
题目大意:给定一个迷宫,S是起点,E是终点,#是墙不可走,.可以走。先输出贴左边墙走到E的步数,再输出贴
右边墙的,再输出最少走多少部能到E。。。
思路:这个是个综合题,BFS和DFS全用上了,代码快3KB了,我靠的,少考虑了一个情况,WA了许久,终于A了 我靠的。。。
8 8
########
#....#.#
#....#.#
#....#.#
#....#.#
#....#.#
S......#
#E######
少考虑了S转个弯就是E的情况。。WA了许久,终于发现这个BUG了。。。。汗。。