# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
430151 | TheWilp | 자동 인형 (IOI18_doll) | C++14 | 95 ms | 12476 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "doll.h"
#include <vector>
#include <iostream>
std::vector<int> f[100005];
int cnt = 1;
std::vector<int> C;
std::vector<int> X;
std::vector<int> Y;
int create(int pos,int left,int right){
if(right == left)
return f[pos][left];
int node_create = cnt;
cnt++;
int mid = (right + left) / 2;
X.push_back(0);Y.push_back(0);
X[node_create - 1] = create(pos,left,mid);
Y[node_create - 1] = create(pos,mid + 1,right);
return -node_create;
}
void print_vector(std::vector<int>& v){
for(int q = 0 ;q<v.size();q++){
std::cout << v[q] << " ";
}std::cout << std::endl;
}
void create_circuit(int M, std::vector<int> A) {
for(int q = 1;q<A.size();q++){
f[A[q - 1]].push_back(A[q]);
}
f[A.back()].push_back(0);
C.push_back(A[0]);
for(int q = 1 ;q<=M;q++){
if(f[q].size() == 0)
C.push_back(0);
else
C.push_back(create(q,0,f[q].size() - 1));
}
//print_vector(C);
//print_vector(X);
//print_vector(Y);
answer(C,X,Y);
}
컴파일 시 표준 에러 (stderr) 메시지
# | 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... |