DFS代码50分5个TLE

B3625 迷宫寻路

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 谢谢大佬指点


|