이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "prize.h"
#include <bits/stdc++.h>
#define sz(x) (int)(x.size())
#define debug printf
#define lp(i,a,b) for(int i = a ; i < b; i++)
#define pb push_back
#define ff first
#define ss second
#define mk make_pair
#define pii pair<int,int>
#define ll long long
#define all(x) x.begin(),x.end()
const int MAX = 2e5+10 ;
using namespace std ;
int cte ;
int soma[MAX] ;
int record[MAX][2] ;
bool went[MAX] ;
bool isLollipop(int i) { return soma[i] == cte ; }
bool isDiamond(int i) { return soma[i] == 0; }
void pergunta(int i)
{
if(went[i]) return ;
went[i] = true ;
vector<int> a = ask(i) ;
record[i][0] = a[0] ;
record[i][1]= a[1] ;
soma[i] = a[0] + a[1] ;
}
int find_best(int n)
{
for(int i = 0 ; i < min(n,480) ; i++ )
{
pergunta(i) ;
if( isDiamond(i) ) return i ;
cte = max(cte, soma[i] ) ;
}
vector<pii> fila(1);
for(int i = 0 ; i < n ; i++ )
{
pergunta(i) ;
if( isDiamond(i) ) return i ;
if( !isLollipop(i) ) continue ;
fila[0].ff = i+1 ;
break ;
}
for(int i= n-1 ; i >= 0 ; i-- )
{
pergunta(i) ;
if(isDiamond(i)) return i ;
if( !isLollipop(i) ) continue ;
fila[0].ss = i-1 ;
break ;
}
int ptr = 0 ;
while( ptr < sz(fila) )
{
int l = fila[ptr].ff ;
int r = fila[ptr].ss ;
ptr++ ;
int mid = (l+r)>>1 ;
pergunta(mid);
//Calculate left interval
int newR = mid ;
while( true )
{
pergunta(newR) ;
if(isDiamond(newR)) return newR ;
if( !isLollipop(newR) ) newR-- ;
else break ;
}
newR-- ;
if( l <= newR && (record[l-1][1] - record[newR+1][1] > 0 ) )
{
fila.push_back( make_pair(l,newR) ) ;
}
//Calculate right interval
int newL = mid ;
while( true )
{
pergunta(newL) ;
if( isDiamond(newL) ) return newL ;
if(!isLollipop(newL)) newL++ ;
else break ;
}
newL++ ;
if( newL <= r && (record[newL-1][1] - record[r+1][1]) > 0 )
fila.push_back( make_pair(newL, r) ) ;
}
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |