求求大佬帮忙看一下k题代码为什么会超时[牛泪][牛泪]
#include<bits/stdc++.h>
using namespace std;
int n,m,ans=100000,s=0;
int vis[505][505],vis2[505][505];
char a[505][505];
int dx[4]={0,0,1,-1};
int dy[4]={1,-1,0,0};
void dfs(int x,int y){
for(int i=0;i<4;i++){
int xx=x+dx[i];
int yy=y+dy[i];
if(xx<1||x>n||yy<1||yy>m) continue;
if(a[xx][yy]=='0'&&!vis[xx][yy]){
vis[xx][yy]=1;
s++;
continue;
}
if(a[xx][yy]=='1'&&!vis2[xx][yy]){
vis2[xx][yy]=1;
dfs(xx,yy);
}
}
return ;
}
int main(){
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
if(a[i][j]=='1'&&!vis2[i][j]){
vis2[i][j]=1;
dfs(i,j);
ans=min(ans,s);
s=0;
memset(vis,0,sizeof(vis));
}
}
}
cout<<ans;
return 0;
}