Submission #570318

#TimeUsernameProblemLanguageResultExecution timeMemory
570318franfillMergers (JOI19_mergers)C++17
70 / 100
3096 ms119264 KiB
#include<bits/stdc++.h> using namespace std; struct dsu { vector < int > pa; vector < int > siz; dsu(int n) { pa.resize(n); siz.resize(n, 1); iota(pa.begin(), pa.end(), 0); } dsu(int n, vector < int > &sizes) : siz(sizes) { pa.resize(n); iota(pa.begin(), pa.end(), 0); } int find(int x) { return pa[x]==x?x:(pa[x]=find(pa[x])); } bool unite(int a, int b) { a=find(a), b=find(b); if (a == b) return false; if (siz[a] < siz[b]) swap(a, b); siz[a] += siz[b]; pa[b] = a; return true; } int get_siz(int x) { return siz[find(x)]; } }; int main() { int n, k; cin >> n >> k; vector < vector < int > > g(n); for (int i = 0; i < n-1; i++) { int a, b; cin >> a >> b; a--, b--; g[a].push_back(b); g[b].push_back(a); } vector < int > state(n), sizes(k, 0); for (auto &s : state) { cin >> s; s--; sizes[s]++; } dsu cities(n), states(k, sizes); vector < int > conn(n, 0); int ans = 0; auto dfs = [&] (int x, int p, auto dfs) -> bool { for (auto y : g[x]) if (y != p) { if (dfs(y, x, dfs)) { conn[x] += conn[y]; //cerr << x << "->" << y << "," << conn[x] << "\n"; cities.unite(x, y); states.unite(state[x], state[y]); } else { cerr << x << "++\n"; conn[x]++; cerr << conn[x] << "\n"; } } if (cities.get_siz(x) == states.get_siz(state[x])) { if (p != -1) conn[x]++; cerr << x << ": " << conn[x] << "\n"; if (conn[x] == 1) ans++; return false; } else { return true; } }; dfs(0, -1, dfs); cout << ans/2 + ans%2 << "\n"; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...