WHY 0

P1141 01迷宫

piyuhan666 @ 2024-09-29 18:55:40

#include<bits/stdc++.h>
using namespace std;
int n,m;
char a[1010][1010];
int f[1010][1010];
int cnt[1010];
void dfs(int x,int y,int z,int h){
    if(x<0 || x>=n || y<0 || y>=n || f[x][y]!=-1 || a[x][y]!=a[x][y]){
        return;
    }
    f[x][y]=h;
    cnt[h]++;
    dfs(x-1,y,!z,h);
    dfs(x+1,y,!z,h);
    dfs(x,y-1,!z,h);
    dfs(x,y+1,!z,h);
}
int main(){
    cin>>n>>m;
    for(int i=0;i<n;i++){
        cin>>a[i];
    }
    memset(f,-1,sizeof(f));
    for(int i=0;i<m;i++){
        int x,y;
        cin>>x>>y;
        x--;
        y--;
        if(f[x][y]==-1){
            dfs(x,y,a[x][y]-'0',i);
        }
        else{
            cnt[i]=cnt[f[x][y]];
        }
    }
    for(int i=0;i<m;i++){
        cout<<cnt[i]<<endl;
    }
    return 0;
}

by lingquan @ 2024-10-01 22:55:42

直接正常BFS做就行


|