样例未过QZ

P1141 01迷宫

worstending @ 2024-01-13 19:10:58

#include<bits/stdc++.h>
using namespace std;
int n,m,ans[100002];
int x,y,flaes[1002][1002];
char s[1002][1002];
int fx[5]={0,1,-1,0,0};
int fy[5]={0,0,0,1,-1};
void dfs(int r,int z,int m,int t){
    if(r<1||r>n||z<1||z>n||flaes[r][z]!=-1||(s[r][z]-'0')!=m){
        return;
    }
    flaes[r][z]=t;
    ans[t]++;
    for(int i=1;i<=4;i++){
        int tx=r+fx[i];
        int ty=z+fy[i];
        dfs(tx,ty,!m,t);
    }
}
int main(){
    cin>>n>>m;
    for (int i=1;i<=n;i++){
        cin>>s[i];
    }
    memset(flaes,-1,sizeof(flaes));
    for (int i=1;i<=m;i++){
        cin>>x>>y;
        if(flaes[x][y]==-1){
            dfs(x,y,s[x][y]-'0',i);
        }
        else{
            ans[i]=ans[flaes[x][y]];
        }
    }
    for(int i=1;i<=m;i++){
        cout<<ans[i]<<endl;
    }
    return 0;
}

|