Submission #755272

#TimeUsernameProblemLanguageResultExecution timeMemory
755272vjudge1Bosses (BOI16_bosses)C++17
67 / 100
253 ms262144 KiB
///***LTT***/// /// ->TUYEN QUOC GIA<- /// #include<bits/stdc++.h> #pragma GCC optimize ("O3") #pragma GCC optimize ("unroll-loops") #pragma GCC target("popcnt") //#define int long long #define F first #define S second #define pb push_back #define CHECKBIT(mask,i) ((mask>>(i) )&1) // == 1 la bat, == 0 la tat #define OFFBIT(mask,i) ((1<<(i))^mask) // tat bit thu i #define ONBIT(mask,i) ((1<<(i))mask) // bat bit thu i using namespace std; const long long oo = 1e9+7; const int N = 2 * 1e5 + 10; int n, p, k, parent[5003][5003]; vector <long long> adj[5003]; bool dd[5002][5002]; long long ans = oo, child[5003][5003], kq[5003][5003]; long long bfs(int u, int g){ queue <int> q; int cnt = 0; q.push(u); long long res = 0; for (int i = 1;i <= n;i++) kq[g][i] = 1; while (!q.empty()){ int u = q.front(); q.pop(); cnt++; dd[g][u] = true; for (int v : adj[u]){ if (!dd[g][v]){ dd[g][v] = true; kq[g][v] = kq[g][u] + 1; q.push(v); child[g][u]++; parent[g][v] = u; } } } for (int i = 1;i <= n;i++){ res += kq[g][i]; } if (cnt < n) return oo; return res; } void inp(){ cin >> n; for (int i = 1;i <= n;i++){ cin >> k; for (int j = 1;j <= k;j++){ cin >> p; adj[p].pb(i); } } for (int i = 1;i <= n;i++){ ans = min(ans,bfs(i,i)); } cout << ans; return; } void solve(){ return; } int main(){ ios_base::sync_with_stdio(NULL); cin.tie(NULL); cout.tie(NULL); // freopen("in.inp", "r", stdin); // freopen("in.out", "w", stdout); inp(); solve(); }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...