标题:迷宫
只看楼主
appleflower
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2007-12-9
 问题点数:0 回复次数:3 
迷宫
#include<iostream.h>
const int m=4,n=4;
int maze[m+2][n+2];//定义迷宫数组
int mark[m+2][n+2];//定义保存访问标记的数组
int move[4][2]={{0,1},{1,0},{0,-1},{-1,0}};//0,1,2,3代表东,西,南,北
int SeekPath(int x,int y)
{
 int i;         //代表从当前位置移到下一位置的方向
 int g,h;       //下一位置坐标
 if((x==m)&&(y==m))return 1;//到达出口点返回ture结束递归
 for(i=0;i<4;i++)
 {
  g=x+move[i][0];h=y+move[i][1];//求下一位置坐标
  if((maze[g][h]==0)&&(mark[g][h]==0))//若下一位置未被访问,则从该位置开始寻找
  {
   mark[g][h]=1;                //已访问结点做好标记
   if(SeekPath(g,h)){
    cout<<"("<<g<<","<<h<<"),";
    return 1;
   }
  }
 }
 cout<<"此迷宫无路径"<<endl<<endl;
 return 0;//无路径,返回false
}
void main()
{   
 int i,j;int q;
 while(q!=0)
 {
 cout<<"请输入6行,6列迷宫数据(0表示通路1表示不通!迷宫四周的值全为1!):"<<endl;
 for(i=0;i<m+2;i++)
  for(j=0;j<n+2;j++)
   cin>>maze[i][j];
    for(i=0;i<m+2;i++)                          //初始化mark数组
  for(j=0;j<n+2;j++)
   mark[i][j]=0;
 mark[1][1]=1;                               //置入口标记为1
 if(SeekPath(1,1))                            //递归求路径
  cout<<"("<<1<<","<<1<<")"<<endl<<endl;
    cout<<"输入另一迷宫按1 结束程序按0"<<endl;
 cin>>q;
 }
}
搜索更多相关主题的帖子: 迷宫 
2007-12-09 12:04
孤魂居士
Rank: 2
来 自:老A(中国地大)
等 级:论坛游民
威 望:4
帖 子:1142
专家分:18
注 册:2007-5-21
得分:0 
可以呀

准备用3年做个高级软件工程师 10年也做不成。准备用10年做成高级软件工程师 3年就成了QQ 群 45771086
欢迎版主...欢迎JAVA爱好者...
一起从深夜 到凌晨...
2007-12-09 12:32
diaoxue
Rank: 1
等 级:新手上路
帖 子:142
专家分:0
注 册:2007-6-1
得分:0 
用do-while可以吧
就是那个q啊 你是想条件判断然后循环吧

上善若水,水善利万物而不争,处众人之所恶
2007-12-09 15:04
编程比卡超
Rank: 1
等 级:新手上路
帖 子:86
专家分:0
注 册:2007-7-27
得分:0 
迷宫有那么简单??我看书上那题队列里面的迷宫长得很咧!!看到就头晕

2007-12-10 18:17



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-191327-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.255348 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved