TaotaoJ @ 2023-06-03 10:21:46
求大佬帮忙改改
#include<bits/stdc++.h>
using namespace std;
int n,m;
char ch[110][100];
bool vis[110][110];
bool dfs(int x,int y)//深搜
{
if(x==n && y==m)
{
return 1;
}
else
{
if(x+1<=n && ch[x+1][y]!='#' && !vis[x+1][y])
{
vis[x+1][y]=1;
if(dfs(x+1,y))
{
return 1;
}
vis[x+1][y]=0;
}
if(x-1>=1 && ch[x-1][y]!='#' && !vis[x-1][y])
{
vis[x-1][y]=1;
if(dfs(x-1,y))
{
return 1;
}
vis[x-1][y]=0;
}
if(y+1<=m && ch[x][y+1]!='#' && !vis[x][y+1])
{
vis[x][y+1]=1;
if(dfs(x,y+1))
{
return 1;
}
vis[x][y+1]=0;
}
if(y-1>=1 && ch[x][y-1]!='#' && !vis[x][y-1])
{
vis[x][y-1]=1;
if(dfs(x,y-1))
{
return 1;
}
vis[x][y-1]=0;
}
}
return 0;
}
int main()
{
ios::sync_with_stdio(false);//优化
cin.tie(NULL);//优化
cout.tie(NULL);//优化
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>ch[i][j];
}
}
bool flag=dfs(1,1);
if(flag)
{
cout<<"Yes";
}
else
{
cout<<"No";
}
return 0;
}
评测记录
by tabelog_AFO @ 2023-06-03 11:09:45
把dfs里所有的vis[...][...]=0
都删掉
改后代码:
#include<bits/stdc++.h>
using namespace std;
int n,m;
char ch[110][100];
bool vis[110][110];
bool dfs(int x,int y)//深搜
{
if(x==n && y==m)
{
return 1;
}
else
{
if(x+1<=n && ch[x+1][y]!='#' && !vis[x+1][y])
{
vis[x+1][y]=1;
if(dfs(x+1,y))
{
return 1;
}
}
if(x-1>=1 && ch[x-1][y]!='#' && !vis[x-1][y])
{
vis[x-1][y]=1;
if(dfs(x-1,y))
{
return 1;
}
}
if(y+1<=m && ch[x][y+1]!='#' && !vis[x][y+1])
{
vis[x][y+1]=1;
if(dfs(x,y+1))
{
return 1;
}
}
if(y-1>=1 && ch[x][y-1]!='#' && !vis[x][y-1])
{
vis[x][y-1]=1;
if(dfs(x,y-1))
{
return 1;
}
}
}
return 0;
}
int main()
{
ios::sync_with_stdio(false);//优化
cin.tie(NULL);//优化
cout.tie(NULL);//优化
cin>>n>>m;
for(int i=1;i<=n;i++)
{
for(int j=1;j<=m;j++)
{
cin>>ch[i][j];
}
}
bool flag=dfs(1,1);
if(flag)
{
cout<<"Yes";
}
else
{
cout<<"No";
}
return 0;
}
原因可以参考这篇讨论
by TaotaoJ @ 2023-06-05 15:00:00
@tabelog 2 谢谢大佬指点