求助:迷宫问题
迷宫问题
问题描述:
以一个m×n的长方阵表示迷宫,0和1分别表示迷宫中的通路和障碍。设计一个程序,对任意设定的迷宫,求出一条从入口到出口的通路,或得出没有通路的结论。
基本要求:
首先实现一个以链表作存储结构的栈类型,然后编写一个求解迷宫的非递归程序。求得的通路以三元组(i,j,d)的形式输出,其中:(i,j)指示迷宫的一个坐标,d表示走到下一个坐标的方向(左--1,下--2,右--3,上--4,当然也可用汉字代替)。如:对于下列数据的迷宫,输出一条通路为:(1,1,1),(1,2,2),(2,2,2),(3,2,3),(3,1,2)……
测试数据:
迷宫的测试数据如下:左上角(1,1)为入口,右下角(8,9)为出口。
实现提示:
计算机解迷宫问题通常用的是回溯发,即从入口出发,顺着某一个方向进行探索,若能走通,则继续往前进;否则沿着原路回退,换一个方向继续探索,直至出口位置,求得一条通路。假如所有可能的通路都探索到而未能达到出口,则所有设定的迷宫没有通路。
可以二维数组存储迷宫数据,通常设定入口点下标为(1,1),出口点下标为(n,n)。为处理方便起见,可在迷宫的四周加一圈障碍。对于迷宫中任一位置,均可约定有东、南、西、北四个方向可通。
求能在visual c++ 6.0环境下能测试通过的源代码,谢谢!