# | Submission time | Handle | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
695205 | 2023-02-04T19:24:08 Z | Mr_Ph | Bosses (BOI16_bosses) | C++14 | 834 ms | 740 KB |
///Never gonna give you up. #include<bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp> typedef long long ll; typedef long long int lli; typedef unsigned long long ull; using namespace std; using namespace __gnu_pbds; template<class x> using ordered_set = tree<x, null_type,less<x>, rb_tree_tag,tree_order_statistics_node_update>; const ll mod=(ll)1e9+7; const ll mod1=998244353; ///the defines :) #define endl '\n' #define vi vector<int> #define vll vector<ll> #define ent(arr) for(int i=0;i<arr.size();i++)cin>>arr[i]; #define all(arr) arr.begin(),arr.end() #define allr(arr) arr.rbegin(),arr.rend() #define sz size() ///the end of the defines ;) void bla() { #ifndef ONLINE_JUDGE freopen("input.txt","r",stdin); freopen("notsus.txt","w",stdout); #endif } int n; vector<vector<int>>padj; vector<vector<int>>adj; vector<int>val; bool valid=false; void build(int node) { for(int i=1;i<=n;i++)val[i]=1; vector<int>mp(n+1); queue<int>q; q.push(node); while(q.sz) { mp[q.front()]++; for(auto i:padj[q.front()]) { if(!mp[i]) { val[i]=val[q.front()]+1; mp[i]++; q.push(i); } } q.pop(); } for(int i=1;i<=n;i++) if(!mp[i])valid=true; } int hello=0; void preprocess(){} void solve() { cin>>n; padj.resize(n+1); adj.resize(n+1); val.resize(n+1); for(int i=0;i<n;i++) { int x; cin>>x; for(int j=0;j<x;j++) { int a; cin>>a; padj[a].push_back(i+1); } } int ans=INT_MAX; for(int i=1;i<=n;i++) { valid=false; build(i); if(valid)continue; hello=0; // dfs(i); for(int j=1;j<=n;j++)hello+=val[j]; ans=min(ans,hello); } cout<<ans<<endl; } int32_t main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); preprocess(); // bla(); int t=1; //cin>>t; while(t--) solve(); }
Compilation message
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 212 KB | Output is correct |
2 | Correct | 0 ms | 212 KB | Output is correct |
3 | Correct | 0 ms | 212 KB | Output is correct |
4 | Correct | 0 ms | 212 KB | Output is correct |
5 | Correct | 0 ms | 212 KB | Output is correct |
6 | Correct | 1 ms | 212 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 212 KB | Output is correct |
2 | Correct | 0 ms | 212 KB | Output is correct |
3 | Correct | 0 ms | 212 KB | Output is correct |
4 | Correct | 0 ms | 212 KB | Output is correct |
5 | Correct | 0 ms | 212 KB | Output is correct |
6 | Correct | 1 ms | 212 KB | Output is correct |
7 | Correct | 1 ms | 212 KB | Output is correct |
8 | Correct | 0 ms | 212 KB | Output is correct |
9 | Correct | 0 ms | 212 KB | Output is correct |
10 | Correct | 1 ms | 212 KB | Output is correct |
11 | Correct | 1 ms | 212 KB | Output is correct |
# | Verdict | Execution time | Memory | Grader output |
---|---|---|---|---|
1 | Correct | 0 ms | 212 KB | Output is correct |
2 | Correct | 0 ms | 212 KB | Output is correct |
3 | Correct | 0 ms | 212 KB | Output is correct |
4 | Correct | 0 ms | 212 KB | Output is correct |
5 | Correct | 0 ms | 212 KB | Output is correct |
6 | Correct | 1 ms | 212 KB | Output is correct |
7 | Correct | 1 ms | 212 KB | Output is correct |
8 | Correct | 0 ms | 212 KB | Output is correct |
9 | Correct | 0 ms | 212 KB | Output is correct |
10 | Correct | 1 ms | 212 KB | Output is correct |
11 | Correct | 1 ms | 212 KB | Output is correct |
12 | Correct | 3 ms | 340 KB | Output is correct |
13 | Correct | 4 ms | 468 KB | Output is correct |
14 | Correct | 176 ms | 660 KB | Output is correct |
15 | Correct | 31 ms | 680 KB | Output is correct |
16 | Correct | 608 ms | 728 KB | Output is correct |
17 | Correct | 794 ms | 736 KB | Output is correct |
18 | Correct | 834 ms | 740 KB | Output is correct |