求助爆0 #1下载下来是对的。。。
查看原帖
求助爆0 #1下载下来是对的。。。
267517
Mikemao666楼主2020/5/30 09:34
#include<bits/stdc++.h>
using namespace std;
const int MAXI=501;
bool p[MAXI][MAXI];
int n,m,ans;
char s;
int d1[4]= {1,0,-1,0};
int d2[4]= {0,1,0,-1};
void dfs(int x,int y) {
	if(x<0||x-1>n||y<0||y-1>m||p[x][y]==1)return;
	p[x][y]=1;
	for(int i=0; i<4; ++i) {
		dfs(x+d1[i],y+d2[i]);
	}
}
int main() {
	cin>>n>>m;
	for(int i=1; i<=n; ++i) {
		for(int j=1; j<=m; ++j) {
			cin>>s;
			if(s=='*')p[i][j]=1;
		}

	}

	dfs(0,0);
	for(int i=1; i<=n; ++i) {
		for(int j=1; j<=m; ++j)	{
			if(p[i][j]==0)ans++;
		}
	}
	cout<<ans<<endl;
	return 0;
}

下载下来的样例1:Here 求助。。


还有题目里的样例排版错误了吧。。。

2020/5/30 09:34
加载中...