Submission #1153878

#TimeUsernameProblemLanguageResultExecution timeMemory
1153878gelastropodSelotejp (COCI20_selotejp)C++20
0 / 110
0 ms324 KiB
#include <bits/stdc++.h>
using namespace std;
#define int long long

vector<int> tree;

int fin(int n) {
	if (tree[n] == n) return n;
	return tree[n] = fin(tree[n]);
}

void join(int a, int b) {
	a = fin(a);
	b = fin(b);
	if (a == b) return;
	tree[a] = b;
}

signed main() {
	int n, m;
	string s;
	cin >> n >> m;
	for (int i = 0; i < n * m; i++) tree.push_back(i);
	vector<vector<bool>> closed(n, vector<bool>(m, false));
	for (int i = 0; i < n; i++) {
		cin >> s;
		for (int j = 0; j < m; j++)
			closed[i][j] = s[j] == '#';
	}
	pair<int, int> dirs[] = {
		{1, 0},
		{-1, 0},
		{0, 1},
		{0, -1}
	};
	int ans = 0;
	for (int i = 0; i < n; i++) {
		for (int j = 0; j < m; j++) {
			if (!closed[i][j]) continue;
			vector<int> neighs;
			for (int k = 0; k < 4; k++) {
				int ci = i + dirs[k].first;
				int cj = j + dirs[k].second;
				if (ci == -1 || ci == n || cj == -1 || cj == m) continue;
				if (closed[ci][cj]) {
					join(i * m + j, ci * m + cj);
					neighs.push_back(ci * m + cj);
				}
			}
			if (neighs.size() == 2 && (neighs[0] / m != neighs[1] / m && neighs[0] % m != neighs[1] % m))
				ans++;
		}
	}
	set<int> ss;
	for (int j : tree) {
		int i = fin(j);
		if (closed[i / m][i % m])
			ss.insert(i);
	}
	cout << ss.size() + ans << '\n';
}
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...