Submission #603304

#TimeUsernameProblemLanguageResultExecution timeMemory
603304DanerZeinArt Collections (BOI22_art)C++17
35 / 100
219 ms7628 KiB
#include "art.h" #include <bits/stdc++.h> using namespace std; map<vector<int>,int> que; int cost(vector<int> x,int i,int j){ x.erase(x.begin()+j); x.insert(x.begin()+i,j+1); if(que.find(x)!=que.end()) return que[x]; return que[x]=publish(x); } void solve(int N) { vector<int> ord; for(int i=1;i<=N;i++) ord.push_back(i); for(int i=1;i<N;i++){ int l=0,r=i; while(r-l>2){ int m1=l+(r-l)/3; int m2=r-(r-l)/3; int c1=cost(ord,m1,i); int c2=cost(ord,m2,i); if(c1>c2){ l=m1; } if(c2>c1){ r=m2; } if(c1==c2){ l=m1; r=m2; } } int mi=1e9; int id=-1; for(int j=l;j<=r;j++){ int rp=cost(ord,j,i); if(rp<mi){ mi=rp; id=j; } } ord.erase(ord.begin()+i); ord.insert(ord.begin()+id,i+1); if(mi==0) break; } answer(ord); }

Compilation message (stderr)

interface.cpp: In function 'int publish(std::vector<int>)':
interface.cpp:20:17: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   20 |     if(v.size() != N) {
      |        ~~~~~~~~~^~~~
interface.cpp: In function 'void answer(std::vector<int>)':
interface.cpp:36:17: warning: comparison of integer expressions of different signedness: 'std::vector<int>::size_type' {aka 'long unsigned int'} and 'int' [-Wsign-compare]
   36 |     if(v.size() != N) {
      |        ~~~~~~~~~^~~~
#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...