听取WA声一片
查看原帖
听取WA声一片
1314528
Oscar111111楼主2025/1/20 15:53
#include<bits/stdc++.h>
using namespace std;
int n,m,sum;
char c[3005][3005];
int book[3005][3005];
int nt[4][2]={{1,0},{-1,0},{0,1},{0,-1}};
void dfs(int x,int y){
	book[x][y]=1;
	for(int i=0;i<=3;i++){
		int tx=x+nt[i][0];
		int ty=y+nt[i][1];
		if(tx>=1&&tx<=n&&ty>=1&&ty<=m){
			if(c[tx][ty]!='*'&&book[tx][ty]==0) dfs(tx,ty);
		}
	}
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++) cin>>c[i][j];
	dfs(1,1);
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++)
			if(c[i][j]!='*'&&book[i][j]==0) sum++;
	}
	cout<<sum;
	return 0;
}

用深搜写的

2025/1/20 15:53
加载中...