제출 #884336

#제출 시각아이디문제언어결과실행 시간메모리
884336vjudge1Bosses (BOI16_bosses)C++17
100 / 100
462 ms3060 KiB
// in the name of God #include<bits/stdc++.h> using namespace std; #define int long long #define double long double #define fast() ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); #define ff first #define ss second #define pb(x) push_back(x) #define all(x) x.begin(), x.end() #define mk make_pair #define ppb pop_back #define endl '\n' #define pii pair<int, int> #define sz(x) (int)x.size() #pragma GCC optimize("Ofast") #pragma GCC optimize("O4") #pragma GCC optimize("unroll-loops") //#pragma GCC target("avx2") mt19937 rng(chrono::steady_clock::now().time_since_epoch().count()); const int mod = 1e9 + 7, maxn = 1e5 + 10, inf = 1e9 + 1, lg = 25, pp = 4447, modd = 1e9 + 9; vector<vector<int>> g(maxn); int n, ans = inf; void bfs(int v){ vector<int> dist(n, inf); vector<int> t(n + 1, 0); dist[v] = 0; queue<int> q; q.push(v); while(q.size()){ int u = q.front(); q.pop(); for(int v : g[u]){ if(dist[v] > dist[u] + 1){ dist[v] = dist[u] + 1; q.push(v); } } } for(int i = 0; i < n; ++i){ if(dist[i] == inf) return; t[dist[i]]++; } int x = 0, anss = 0; for(int i = n; i >= 0; --i){ x += t[i]; anss += x; } ans = min(ans, anss); } signed main(){ fast(); cin >> n; for(int i = 0; i < n; ++i){ int t; cin >> t; for(int j = 0; j < t; ++j){ int u; cin >> u; u--; g[u].pb(i); } } for(int i = 0; i < n; ++i){ bfs(i); } cout << ans; } // Running from the daylight...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...