我的代码为什么只有60分

B3625 迷宫寻路

shiyq @ 2024-08-09 22:06:53

3个WA 2个RE

#include<bits/stdc++.h>
using namespace std;
int a[101][101],n,m;
int pd=0;
int tx[5]={0,1,0,-1,0};
int ty[5]={0,0,1,0,-1};
void dfs(int x,int y)
{

    if(pd==1)
    {
        return ;
    }
    if(x==n and y==m)
    {
        pd=1;

        return ;

    }
    for(int i=1;i<=4;i++)   
    {
        int txx=x+tx[i];
        int tyy=y+ty[i];
        if(txx<1 or txx>n or tyy<1 or txx>m)
        {
            continue;
        }
        if(a[txx][tyy]==0)
        {
            a[txx][tyy]=1;
            dfs(txx,tyy);
        }
    }

}
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=m;j++)
        {
            char x;
            cin>>x;
            if(x=='.') a[i][j]=0;
            else a[i][j]=1;
        }
    }
    dfs(1,1);
    if(pd==1){
        cout<<"Yes";
    }
    else
    {
        cout<<"No";
    }
}

by kkk_kkkk @ 2024-08-09 22:29:12

25行《if(txx<1 or txx>n or tyy<1 or txx>m)》


by shiyq @ 2024-08-10 10:54:39

@kkk_kkkk @kkk_kkkk ok


|