社区讨论
样例全过提交全wa求条
P1506拯救oibh总部参与者 1已保存回复 1
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 1 条
- 当前快照
- 1 份
- 快照标识符
- @mhizmhtf
- 此快照首次捕获于
- 2025/11/03 18:18 4 个月前
- 此快照最后确认于
- 2025/11/03 18:18 4 个月前
CPP
#include<bits/stdc++.h>
using namespace std;
string hb[505];
int n, m;
int ans = 0;
bool check(int x,int y)
{
return x>=0 && x<n && y>=0 && y<m && hb[x][y]=='0';
}
void dfs(int x,int y)
{
if(!check(x,y))
{
return;
}
if(hb[x][y]=='*')
{
return;
}
else
{
hb[x][y] = '*';
dfs(x+1,y);
dfs(x-1,y);
dfs(x,y+1);
dfs(x,y-1);
return;
}
}
int output()
{
for(int i = 0; i < n; i++)
{
for(int j = 0; j < m; j++)
{
if(hb[i][j]=='0')
{
ans++;
//dfs(i,j);
}
}
}
return ans;
}
int main()
{
cin >> n >> m;
for(int i = 0; i < n; i++)
{
cin >> hb[i];
}
dfs(0, 0);
dfs(n-1, m-1);
dfs(0, n-1);
dfs(0, m-1);
cout << output() << endl;
return 0;
}
我的思路是将会被洪水覆盖的区域全替成*然后枚举找到没变的0
回复
共 1 条回复,欢迎继续交流。
正在加载回复...