Submission #65253

#TimeUsernameProblemLanguageResultExecution timeMemory
65253FedericoSPaint By Numbers (IOI16_paint)C++14
10 / 100
2064 ms924 KiB
#include "paint.h" #include <cstdlib> #include <assert.h> #include <iostream> using namespace std; int N,K; int C[100005]; string S; string F(int i, int j){ if(C[j]>=i+2 or i<0) return "z"; for(int p=i;p>i-C[j];p--) if(S[p]=='_') return "z"; string s(i+1,'0'); if(j==0){ for(int p=i-C[j];p>=0;p--) if(S[p]=='X') return "z"; for(int p=0;p<=i-C[j];p++) s[p]='_'; for(int p=i-C[j]+1;p<=i;p++) s[p]='X'; return s; } else{ bool flag=false; for(int p=i-C[j];p>=0;p--){ if(S[p]=='X') break; if(F(p-1,j-1)!="z"){ if(!flag){ s=F(p-1,j-1); for(int q=p;q<=i-C[j];q++) s.push_back('_'); flag=true; } else{ string r; r=F(p-1,j-1); for(int q=p;q<=i-C[j];q++) r.push_back('_'); assert(s.size()==r.size()); for(int q=0;q<=i-C[j];q++) if(s[q]!=r[q]) s[q]='.'; } } } if(!flag) return "z"; for(int p=i-C[j]+1;p<=i;p++) s.push_back('X'); return s; } } string solve_puzzle(string s_, vector<int> c_) { N=s_.size(); K=c_.size(); S=s_; for(int i=0;i<N;i++) C[i]=c_[i]; //for(int i=0;i<N;i++)for(int j=0;j<K;j++)cout<<i<<" "<<j<<" "<<F(i,j)<<"\n"; string A,B; bool flag=false; for(int i=0;i<N;i++) if(F(i,K-1)!="z"){ B=(F(i,K-1)); while(B.size()<N) B.push_back('_'); if(!flag){ A=B; flag=true; } else for(int i=0;i<N;i++) if(A[i]!=B[i]) A[i]='.'; } for(int i=0;i<N;i++) if(A[i]=='.') A[i]='?'; return A; }

Compilation message (stderr)

paint.cpp: In function 'std::__cxx11::string solve_puzzle(std::__cxx11::string, std::vector<int>)':
paint.cpp:99:27: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
             while(B.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...
#Verdict Execution timeMemoryGrader output
Fetching results...