社区讨论

第二个点WA??求帮助

P114101迷宫参与者 2已保存回复 2

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
2 条
当前快照
1 份
快照标识符
@mi6n228d
此快照首次捕获于
2025/11/20 07:33
4 个月前
此快照最后确认于
2025/11/20 07:33
4 个月前
查看原帖
第二个点WA??求帮助
CPP
#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include<algorithm>
#include<cstring>
using namespace std;
int n,m,a[1005][1005],ax,ay,ans=0,cc=0,col[100005]={0},p=0,c[1005][1005]={{0},{0}};
bool fll=0,k=0,in[1001][1001]={{0},{0}};
string s;
int dx[]={0,1,-1,0,0},
    dy[]={0,0,0,1,-1};
void dfs(int x,int y,int color,int last,int step)
{
    if(x>n||x<1||y>n||y<1) return;
    if(last==a[x][y]&&step>1) return;
    if(in[x][y]) return;
    ans++;c[x][y]=color;in[x][y]=1;
    for(int i=1;i<=4;i++)
    {
        ax=x+dx[i],ay=y+dy[i];
        dfs(ax,ay,color,a[x][y],step+1);
    }
}
int main()
{
//    freopen("testdata.in","r",stdin);
//    freopen("testdata(1).out","w",stdout);
    scanf("%d%d\n",&n,&m);
    for(int i=1;i<=n;i++)
    {
        getline(cin,s);
        for(int j=0;j<s.size();j++)
            a[i][j+1]=s[j]-48;
    }
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
        {
            ans=0;
            if(!in[i][j])
            dfs(i,j,++cc,a[i][j],1),col[cc]=ans;
        }
    for(int i=1;i<=m;i++)
    {
        scanf("%d%d",&ax,&ay);
        printf("%d\n",col[c[ax][ay]]);
    }
    return 0;
}

回复

2 条回复,欢迎继续交流。

正在加载回复...