http://acm.zju.edu.cn/onlinejudge/
#include<iostream>
using namespace std;
#define MAX 7
char map[MAX][MAX];
int visited,count,m,n,flag;
void dfs(int x,int y)
{
if(x<0||x>=n||y<0||y>=m)
return ;
if(map[x][y]=='S')
return ;
if(flag)
return ;
count++;
if(count>1500)
return ;
visited++;
if(visited==m*n)
{
flag=1;
return ;
}
map[x][y]='S';
dfs(x+1,y);
dfs(x-1,y);
dfs(x,y+1);
dfs(x,y-1);
visited--;
map[x][y]='.';
}
int main()
{
while(cin>>n>>m&&(m||n))
{
visited=0;
for(int i=0;i<n;i++)
for(int j=0;j<m;j++)
{
cin>>map[i][j];
if(map[i][j]=='S')
visited++;
}
flag=0;
count=0;
dfs(0,0);
if(flag)
cout<<"YES"<<endl;
else
cout<<"NO"<<endl;
}
return 0;
}
showProblem.do?problemId=1100 点击打开链接
本文介绍了一个使用深度优先搜索(DFS)解决迷宫问题的C++代码实现。该算法通过递归地访问迷宫中的每个位置来判断是否可以从起点到达终点。如果所有可到达的位置都被访问过,则认为找到了一条从起点到终点的路径。

437

被折叠的 条评论
为什么被折叠?



