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 "elephants.h"
#include<cstdio>
#include<vector>
#include<algorithm>
int a,b,sq,t,how,dpsz,z[150002],x[150002],yy[150002],D[391][781],len[391][781],LEN[391][781],sz[391];
void madp(int num)
{
len[num][sz[num]]=2000000001;
int q=0;
for(int j=0;j<sz[num];j++)
{
while(len[num][q]<=len[num][j]+b)q++;
z[j]=q;
}
for(int j=sz[num]-1;j>=0;j--)
{
if(z[j]==sz[num])
{
D[num][j]=1;
LEN[num][j]=len[num][j]+b;
}
else
{
D[num][j]=1+D[num][z[j]];
LEN[num][j]=LEN[num][z[j]];
}
}
}
void makedp()
{
int u=0;
for(int j=0;j<dpsz;j++)sz[j]=0;
for(int j=0;j<a;j++)
{
if(j!=0&&j%sq==0)u++;
len[u][sz[u]++]=yy[j];
}
for(int j=0;j<dpsz;j++)
{
madp(j);
}
}
void erase(int p)
{
int o;
for(int j=0;j<dpsz;j++)
{
if(sz[j]&&len[j][0]<=p&&p<=len[j][sz[j]-1])
{
o=j;
break;
}
}
for(int j=0;j<sz[o];j++)
{
if(len[o][j]==p)
{
for(int k=j+1;k<sz[o];k++)
{
len[o][k-1]=len[o][k];
}
break;
}
}
sz[o]--;
if(sz[o])madp(o);
}
void add(int p)
{
int o=-1;
for(int j=0;j<dpsz;j++)
{
if(sz[j]&&len[j][0]<=p)o=j;
}
if(o==-1)o=0;
if(len[o][sz[o]-1]<=p)len[o][sz[o]]=p,sz[o]++;
else
{
for(int j=0;j<sz[o];j++)
{
if(len[o][j]>=p)
{
for(int k=sz[o];k>j;k--)
{
len[o][k]=len[o][k-1];
}
len[o][j]=p;
}
}
sz[o]++;
}
madp(o);
}
void init(int N,int L,int X[])
{
a=N;
b=L;
sq=0;
for(;sq*sq<=a;sq++);
sq--;
dpsz=(a+sq-1)/sq;
for(int i=0;i<a;i++)yy[i]=x[i]=X[i];
makedp();
}
int update(int i,int y)
{
erase(x[i]);
x[i]=y;
add(y);
int ans=0,l=-1,P,Q,H;
for(int j=0;j<dpsz;j++)
{
if(sz[j]==0)continue;
if(len[j][sz[j]-1]<=l)continue;
P=-1;
Q=sz[j]-1;
while(P!=Q-1)
{
H=(P+Q)/2;
if(len[j][H]<=l)P=H;
else Q=H;
}
l=LEN[j][Q];
ans+=D[j][Q];
}
how++;
if(how%sq==0)
{
t=0;
for(int j=0;j<dpsz;j++)
{
for(int k=0;k<sz[j];k++)
{
yy[t++]=len[j][k];
}
}
makedp();
}
return ans;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |