Submission #596577

#TimeUsernameProblemLanguageResultExecution timeMemory
5965771zaid1Bosses (BOI16_bosses)C++17
67 / 100
1594 ms1184 KiB
#include <bits/stdc++.h> using namespace std; #define endl '\n' #define int long long const int M = 1e4+2; vector<int> node[M], nod[M]; bitset<5005> vis; int n; int check(int s) { vis = 0; vis[s] = true; queue<int> q; q.push(s); int cnt = 0; while (!q.empty()) { int f = q.front(); q.pop(); for (int i:node[f]) { if (!vis[i]) { vis[i] = true; q.push(i); } } cnt++; } return cnt; } pair<int, int> dfs(int s) { int a = 0, b = 0; vis[s] = true; for (int i:nod[s]) { if (!vis[i]) { auto [x, y] = dfs(i); a += x; b += y; } } return {a+1, b+a+1}; } int solve(int s) { vis = 0; vis[s] = true; queue<int> q; q.push(s); for (int i = 1; i <= n; i++) nod[i].clear(); while (!q.empty()) { int f = q.front(); q.pop(); for (int i:node[f]) { if (!vis[i]) { vis[i] = true; nod[f].push_back(i); q.push(i); } } } vis = 0; return dfs(s).second; } signed main() { cin.tie(0)->sync_with_stdio(0); cin >> n; for (int i = 1; i <= n; i++) { int m; cin >> m; for (int j = 1; j <= m; j++) { int a; cin >> a; node[a].push_back(i); } } int mn = INT_MAX; for (int i = 1; i <= n; i++) { if (check(i) == n) mn = min(mn, solve(i)); } cout << mn << endl; return 0; } /* 4 1 4 3 1 3 4 2 1 2 1 3 */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...