Nucky_ 2015-01-31 06:45 采纳率: 33.3%
浏览 2090
已结题

关于使用回溯法求解迷宫问题

#include
using namespace std ;
const int m = 4 , p = 4 ;
struct offsets {
int a , b ;
char *dir ;
};
offsets move[8] ;
int Maze[m+2][p+2] ;
int mark[m+2][p+2] ;
int main (){
int i , j;
int SeekPath (int x ,int y ) ;
offsets move[8] = {{-1,0,"N"},{-1,1,"NE"},{0,1,"E"},{1,1,"SE"},{1,0,"S"},{1,-1,"SW"},{0,-1,"W"},{-1,-1,"NW"}} ;
for(i = 0 ;i< m+2 ;i++) {
for(j=0;j

cin >> Maze[i][j] ;
}
}
for(i = 0 ;i < m+2 ;i++) {
for(j = 0;j<p+2 ;j++) {
mark[i][j] = 0 ;
}
}
mark[1][1] = 1 ;
if(SeekPath(1,1)) {
cout << "(" << 1 << "," << 1 << ") ," << "dir" << "E" <<endl;
}
}

int SeekPath (int x ,int y ) {
int i ,g ,h ;
char *d;
if(x == m && y == p) return 1 ;
for(i = 0 ;i < 8 ;i++) {
g = x+ move[i].a ;
h = y+ move[i].b ;
d = move[i].dir ;
if(Maze[g][h] == 0 && mark[g][h] == 0) {
mark[g][h] = 1 ;
if (SeekPath (g,h)) {
cout << "(" << g <<"," << h <<")," << "dir" <<" ," ;
return 1 ;
}
}
}
if(x == 1 && y== 1 ) cout << "no path in Maze " <<endl ;
return 0 ;

}

不知道为何输入地图进去后总是显示 "no path in Maze"
两天了实在找不到问题在哪,希望能有大神帮忙指点

  • 写回答

2条回答 默认 最新

  • Nucky_ 2015-01-31 10:26
    关注

    来个大神啊 = = 实在不知道哪里出问题了,改了好几遍了

    评论

报告相同问题?

悬赏问题

  • ¥100 求三轴之间相互配合画圆以及直线的算法
  • ¥100 c语言,请帮蒟蒻写一个题的范例作参考
  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 自己瞎改改,结果现在又运行不了了
  • ¥15 链式存储应该如何解决
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站