Submission #220732

#TimeUsernameProblemLanguageResultExecution timeMemory
220732NONAMESkandi (COCI20_skandi)C++17
110 / 110
4276 ms19064 KiB
#include <bits/stdc++.h> #include <time.h> //#include <random> //#ifndef _LOCAL //#pragma GCC optimize("-O3") //#pragma GCC optimize("Ofast") //#pragma GCC optimize("unroll-loops") //#endif #define sz(x) int(x.size()) #define in(x) freopen(x, "r", stdin) #define out(x) freopen(x, "w", stdout) #define N 100500 #define oo ll(1e16) #define pii pair <int, int> #define pll pair <ll, ll> #define ft first #define sd second #define pb push_back #define ppb pop_back #define mp make_pair #define el '\n' #define elf endl #define base ll(1e9 + 7) #define re return #define nins 4294967295 using namespace std; typedef long long ll; typedef long double ld; //mt19937 rnd(0); pii ver_co[501 * 501], hor_co[501 * 501]; int n, m, ver, hor; vector <int> mV, mH, g[501 * 501], mkV, mkH; vector <char> mk; map <pii, int> ver_id, hor_id; string s[501]; bool try_kuhn(int v) { if (mk[v]) return 0; mk[v] = 1; for (int i = 0; i < sz(g[v]); i++) { int to = g[v][i]; if (mH[to] == -1 || try_kuhn(mH[to])) { mH[to] = v; return 1; } } return 0; } void dfs(int v) { mkV[v] = 1; for (int i = 0; i < sz(g[v]); i++) { int to = g[v][i]; if (mkH[to]) continue; mkH[to] = 1; dfs(mH[to]); } } void solve() { cin >> n >> m; for (int i = 0; i < n; i++) cin >> s[i]; for (int i = 0; i < n; i++) for (int j = 0; j < m; j++) { if (s[i][j] == '0') continue; if (i + 1 < n && s[i + 1][j] == '0') { ver_id[{i, j}] = ver; ver_co[ver++] = {i + 1, j + 1}; } if (j + 1 < m && s[i][j + 1] == '0') { hor_id[{i, j}] = hor; hor_co[hor++] = {i + 1, j + 1}; } } for (int i = 0; i < n; i++) for (int j = 0; j < m; j++) { if (s[i][j] == '1') continue; int _i = i, _j = j; while (s[_i][j] == '0') _i--; while (s[i][_j] == '0') _j--; g[ver_id[{_i, j}]].pb(hor_id[{i, _j}]); } int rs = 0; mV.assign(ver, -1); mH.assign(hor, -1); for (int i = 0; i < ver; i++) { mk.assign(ver, 0); rs += try_kuhn(i); } cout << rs << el; mkV.assign(ver, 0); mkH.assign(hor, 0); for (int i = 0; i < hor; i++) if (mH[i] != -1) mV[mH[i]] = i; for (int i = 0; i < ver; i++) { if (mV[i] != -1) continue; dfs(i); } for (int i = 0; i < ver; i++) if (!mkV[i]) cout << ver_co[i].ft << ' ' << ver_co[i].sd << " DOLJE" << el; for (int i = 0; i < hor; i++) if (mkH[i]) cout << hor_co[i].ft << ' ' << hor_co[i].sd << " DESNO" << el; } int main() { ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); #ifdef _LOCAL in("input.txt"); int t = 1; // cin >> t; for (int i = 1; i <= t; i++) { cout << "Test #" << i << elf; clock_t start_time = clock(); solve(); cerr.precision(4); cerr << fixed; cerr << elf; cerr << "Time :: " << ld(clock() - start_time) / CLOCKS_PER_SEC << elf; cout << elf; } #else int t = 1; // cin >> t; while (t--) { solve(); cout << el; } #endif }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...