#include
using namespace std;
const int N = 1010;
int m, n;
char g[N][N];
static constexpr int dirs[][2] {{0, -1}, {-1, -1}, {-1, 0}, {-1, 1},
{0, 1}, {1, 1}, {1, 0}, {1, -1}};
void dfs(int x, int y) {
if (x < 0 || y < 0 || x == n || y == m || g[y][x] == '.')
return;
g[y][x] = '.'; // mark as seen
for (int i = 0; i < 8; ++i)
dfs(x + dirs[i][0], y + dirs[i][1]);
}
int main() {
cin >> m >> n;
for (int y = 0; y < m; ++y)
for (int x = 0; x < n; ++x) cin >> g[y][x];
int ans = 0;
for (int y = 0; y < m; ++y)
for (int x = 0; x < n; ++x) {
ans += g[y][x] == 'W';
dfs(x, y);
}
cout << ans << endl;
return 0;
}
==是逻辑判断,如果等于'W',那么计数加1
==的优先级大于+=,所以先执行==,然后执行+=。
ans += g[y][x] == ‘W’ 等价于
if (g[y][x] == 'W') // ==运算的结果只有2个,真或者假,1为真,0为假
ans += 1;
else
ans += 0;