Submission #547177

#TimeUsernameProblemLanguageResultExecution timeMemory
547177AlexRex0Last supper (IOI12_supper)C++14
0 / 100
373 ms14920 KiB
#include "advisor.h" void ComputeAdvice(int *C, int N, int K, int M) { /// funciona para mandar el numero WriteAdvice(); int bitsOcupo = 0; if(N <= 5000){ bitsOcupo = 13; }else{ bitsOcupo = 17; } for(int i = 0; i < N; ++i){ int num = C[i]; int bits = 0; while(num > 0){ WriteAdvice(num % 2); bits++; num/=2; } for(int j = bits + 1; j <= bitsOcupo; ++j){ WriteAdvice(0); } } }
#include <bits/stdc++.h> #include "assistant.h" using namespace std; priority_queue<pair<int, int> > colaP; int apariciones[100002]; int sigAparicion[100002]; int ultima[100002]; void Assist(unsigned char *A, int N, int K, int R) { int bitsOcupo = 0; if(N <= 5000){ bitsOcupo = 13; }else{ bitsOcupo = 17; } int secOriginal[100002]; /// pongo los que tengo actualmente en el andamio int pos = 0; for(int i = 1; i <= N; ++i){ int num = 0; int pot = 1; for(int j = 1; j <= bitsOcupo; ++j){ if((int)A[pos] == 1){ num+= pot; } //cout << (int)A[pos] << ' '; pot*=2; pos++; } secOriginal[i - 1] = num; } for(int i = N - 1; i >= 0; --i){ apariciones[i] = INT_MAX; ultima[i] = INT_MAX; } for(int i = N - 1; i >= 0; --i){ sigAparicion[i] = apariciones[secOriginal[i]]; ultima[secOriginal[i]] = sigAparicion[i]; apariciones[secOriginal[i]] = i; } /// el first es la posicion de la siguiente aparicion /// el second es el color bool andamio[100002]; for(int i = 0; i < N; ++i){ if(i < K){ andamio[i] = true; colaP.push({ultima[i], i}); }else{ andamio[i] = false; } } for(int i = 0; i < N; ++i){ int sigColor = GetRequest(); if(!andamio[sigColor]){ pair<int, int> aux; aux = colaP.top(); colaP.pop(); PutBack(aux.second); //cout << '\n' << aux.second << '\n'; andamio[aux.second] = false; andamio[sigColor] = true; colaP.push({sigAparicion[i], sigColor}); } } }
#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...