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>
#include "shortcut.h"
using namespace std;
using ll=long long;
const ll MAX_SOM=3000+5,INFINI=(ll)1000*1000*1000*1000*1000*1000,DECA=(1<<12);
ll nbSom,prixNouv,rep;
ll cumu[MAX_SOM];
ll distStat[MAX_SOM];
ll arbreMax[2*DECA][2],memo[MAX_SOM][MAX_SOM];
ll calcDist(ll a,ll b) {
if (a>b) {
swap(a,b);
}
return cumu[b]-cumu[a];
}
ll calcMax(ll deb,ll fin,ll tab) {
if (deb==fin) {
return arbreMax[deb][tab];
}
if (deb%2==1) {
return max(arbreMax[deb][tab],calcMax(deb+1,fin,tab));
}
if (fin%2==0) {
return max(arbreMax[fin][tab],calcMax(deb,fin-1,tab));
}
return calcMax(deb/2,fin/2,tab);
}
ll calcInter(ll deb,ll fin) {
if (deb>=fin) {
return 0;
}
if (memo[deb][fin]!=-1) {
return memo[deb][fin];
}
memo[deb][fin]=max(calcInter(deb+1,fin),calcMax(DECA+deb+1,DECA+fin,0)+distStat[deb]-cumu[deb]);
return memo[deb][fin];
}
ll calcDiam(ll deb,ll fin) {
ll diam=max(calcInter(0,deb),calcInter(fin,nbSom-1));
ll tempDeb=distStat[deb],tempFin=distStat[fin];
if (deb!=0) {
distStat[deb]=max(cumu[deb]+calcMax(DECA,DECA+deb-1,1),distStat[deb]);
}
if (fin!=nbSom-1) {
distStat[fin]=max(calcMax(DECA+fin+1,DECA+nbSom-1,0)-cumu[fin],distStat[fin]);
}
ll somGlob=cumu[fin]-cumu[deb]+prixNouv,dist;
for (ll a=deb;a<=fin;a++) {
if (diam>=rep) {
distStat[deb]=tempDeb;
distStat[fin]=tempFin;
return diam;
}
for (ll b=a+1;b<=fin;b++) {
dist=calcDist(a,b);
diam=max(diam,min(dist,somGlob-dist)+distStat[a]+distStat[b]);
}
}
distStat[deb]=tempDeb;
distStat[fin]=tempFin;
//cout<<deb<<" "<<fin<<" "<<diam<<endl;
return diam;
}
ll find_shortcut(int n,vector<int> l,vector<int> d,int c) {
nbSom=n;
for (int i=0;i<nbSom;i++) {
for (int j=0;j<nbSom;j++) {
memo[i][j]=-1;
}
}
prixNouv=c;
for (ll i=1;i<nbSom;i++) {
cumu[i]=cumu[i-1]+l[i-1];
}
for (ll i=0;i<nbSom;i++) {
distStat[i]=d[i];
}
for (ll i=0;i<2*DECA;i++) {
arbreMax[i][0]=-INFINI;
arbreMax[i][1]=-INFINI;
}
for (ll i=0;i<nbSom;i++) {
arbreMax[DECA+i][0]=distStat[i]+cumu[i];
arbreMax[DECA+i][1]=distStat[i]-cumu[i];
}
for (ll i=DECA-1;i>0;i--) {
arbreMax[i][0]=max(arbreMax[2*i][0],arbreMax[2*i+1][0]);
arbreMax[i][1]=max(arbreMax[2*i][1],arbreMax[2*i+1][1]);
}
rep=INFINI;
vector<tuple<ll,ll,ll>> ordre;
for (ll i=0;i<nbSom;i++) {
for (ll j=i+1;j<nbSom;j++) {
ordre.push_back({i-j,i,j});
}
}
sort(ordre.begin(),ordre.end());
for (auto i:ordre) {
rep=min(rep,calcDiam(get<1>(i),get<2>(i)));
}
return rep;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |