Submission #836453

#TimeUsernameProblemLanguageResultExecution timeMemory
836453oscar1fShortcut (IOI16_shortcut)C++17
31 / 100
2069 ms5964 KiB
#include<bits/stdc++.h> #include "shortcut.h" using namespace std; using ll=long long; const int MAX_SOM=3000+5,DECA=(1<<12); const ll INFINI=(ll)1000*1000*1000*1000*1000*1000; int nbSom,prixNouv; ll rep; ll cumu[MAX_SOM]; ll distStat[MAX_SOM]; ll arbreMax[2*DECA],memo[MAX_SOM][MAX_SOM]; ll calcDist(int a,int b) { if (a>b) { swap(a,b); } return cumu[b]-cumu[a]; } ll calcMax(int deb,int fin) { if (deb==fin) { return arbreMax[deb]; } if (deb%2==1) { return max(arbreMax[deb],calcMax(deb+1,fin)); } if (fin%2==0) { return max(arbreMax[fin],calcMax(deb,fin-1)); } return calcMax(deb/2,fin/2); } ll calcInter(int deb,int 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)+distStat[deb]-cumu[deb]); return memo[deb][fin]; } ll calcDiam(int deb,int fin) { ll diam=max(calcInter(0,deb),calcInter(fin,nbSom-1)); ll tempDeb=distStat[deb],tempFin=distStat[fin]; for (int i=0;i<deb;i++) { distStat[deb]=max(distStat[deb],calcDist(i,deb)+distStat[i]); } for (int i=fin+1;i<nbSom;i++) { distStat[fin]=max(distStat[fin],calcDist(fin,i)+distStat[i]); } ll somGlob=cumu[fin]-cumu[deb]+prixNouv,dist; for (int a=deb;a<=fin;a++) { if (diam>=rep) { distStat[deb]=tempDeb; distStat[fin]=tempFin; return diam; } for (int 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 (int i=1;i<nbSom;i++) { cumu[i]=cumu[i-1]+l[i-1]; } for (int i=0;i<nbSom;i++) { distStat[i]=d[i]; } for (int i=0;i<nbSom;i++) { arbreMax[DECA+i]=distStat[i]+cumu[i]; } for (int i=DECA-1;i>0;i--) { arbreMax[i]=max(arbreMax[2*i],arbreMax[2*i+1]); } rep=INFINI; vector<tuple<int,int,int>> ordre; for (int i=0;i<nbSom;i++) { for (int 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 timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...