This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#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 time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |