제출 #156668

#제출 시각아이디문제언어결과실행 시간메모리
156668a_playerGap (APIO16_gap)C++14
44.36 / 100
131 ms2040 KiB
#include <bits/stdc++.h> #include "gap.h" #define f first #define s second #define mp make_pair #define pb push_back using namespace std; typedef long long ll; ll mas=0; ll vv[100001]; int k=0; void ric(ll a,ll b){ ll u,v; MinMax(a,b,&u,&v); if(u==-1&&v==-1)return; if(u==v){vv[k++]=u; return;} if(v-u==1){ ric(u,u); ric(v,v); return; } if(v-u==2){ ric(u,u); ric(u+1,u+1); ric(v,v); return; } ll m=(v-u)/3; ric(u,u+m); ric(u+m+1,u+2*m); ric(u+2*m+1,v); } int findGap(int T,int N){ if(T==2){ ll g=1; for(int i=0;i<18;i++)g*=10LL; ric(0LL,g); for(int i=0;i<N;i++)mas=max(mas,vv[i+1]-vv[i]); return mas; } ll a=0,b=1000000000000000000; int i=0,j=N-1; while(i<=j){ MinMax(a,b,&a,&b); vv[i]=a; vv[j]=b; i++; j--; a++; b--; } for(int i=0;i<N-1;i++)mas=max(mas,vv[i+1]-vv[i]); return mas; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...