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
    关注

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

    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器