Submission #168847

#TimeUsernameProblemLanguageResultExecution timeMemory
168847LawlietJousting tournament (IOI12_tournament)C++17
0 / 100
91 ms15428 KiB
#include <bits/stdc++.h> using namespace std; const int LOG = 20; const int MAXN = 200010; class FenwickTree { public: void update(int i, int v) { for( ; i < MAXN ; i += i & -i ) BIT[ i ] += v; } int query(int i) { int ans = 0; for( ; i > 0 ; i -= i & -i ) ans += BIT[ i ]; return ans; } FenwickTree() { memset( BIT , 0 , sizeof(BIT) ); } private: int BIT[MAXN]; }; int n; int cntNode; int mx[MAXN]; int prof[MAXN]; int dp[LOG][MAXN]; int virtualNode[MAXN]; vector< int > adj[MAXN]; FenwickTree BIT; void DFS(int cur) { for(int k = 1 ; k < LOG ; k++) dp[k][cur] = dp[k - 1][ dp[k - 1][cur] ]; for(int i = 0 ; i < adj[cur].size() ; i++) { int viz = adj[cur][i]; prof[ viz ] = prof[ cur ] + 1; DFS( viz ); } } int getKthKnight(int k) { int l = 1; int r = n; if( BIT.query( 1 ) == k ) return 1; while( l < r ) { int m = ( l + r )/2; if( l == r - 1 ) m = r; if( BIT.query( m ) < k ) l = m; else r = m - 1; } return l + 1; } int LCA(int U, int V) { if( prof[U] < prof[V] ) swap( U , V ); int d = prof[U] - prof[V]; for(int k = 0 ; k < LOG ; k++) if( d & (1 << k) ) U = dp[k][U]; if( U == V ) return U; for(int k = LOG - 1 ; k >= 0 ; k--) { if( dp[k][U] != dp[k][V] ) { U = dp[k][U]; V = dp[k][V]; } } return dp[0][U]; } int GetBestPosition(int N, int C, int R, int *K, int *S, int *E) { n = N; cntNode = n; for(int i = 1 ; i <= n ; i++) { virtualNode[i] = i; BIT.update( i , 1 ); } for(int i = 0 ; i < C ; i++) { cntNode++; E[i]++; S[i]++; int sz = E[i] - S[i] + 1; for(int j = 0 ; j < sz ; j++) { int cur = getKthKnight( S[i] ); dp[0][ virtualNode[cur] ] = cntNode; adj[ cntNode ].push_back( virtualNode[cur] ); if( j != sz - 1 ) BIT.update( cur , -1 ); } int last = getKthKnight( S[i] ); virtualNode[ last ] = cntNode; } DFS( cntNode ); int ans = 0; int last = cntNode; for(int i = 1 ; i <= n ; i++) { int l = LCA( i , last ); mx[i] = prof[i] - prof[l] - 1; if( K[i] > R ) last = i; } last = cntNode; for(int i = n ; i > 0 ; i--) { int l = LCA( i , last ); mx[i] = min( mx[i] , prof[i] - prof[l] - 1 ); if( K[i] > R ) last = i; ans = max( ans , mx[i] ); } return ans; }

Compilation message (stderr)

tournament.cpp: In function 'void DFS(int)':
tournament.cpp:52:20: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for(int i = 0 ; i < adj[cur].size() ; i++)
                  ~~^~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...