이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#include "doll.h"
using namespace std;
int n, m, s, cnt;
vector <int> x, y, c, a;
void build (int node, int l, int r, int idx, int p){
if (r - l == 1){
if (idx >= n) x[node - 1] = -1;
else x[node - 1] = a[idx];
if (idx + p >= n) y[node - 1] = -1;
else y[node - 1] = a[idx + p];
return;
}
int mid = (l + r) / 2;
x[node - 1] = -(node * 2);
y[node - 1] = -(node * 2 + 1);
build (node * 2, l, mid, idx, p * 2);
build (node * 2 + 1, l, mid, idx + p, p * 2);
}
void create_circuit(int M, vector<int> A) {
a = A;
s = n = A.size();
m = M;
while (__builtin_popcount(s) != 1) s += s & -s;
x.resize(s - 1);
y.resize(s - 1);
c.resize(m + 1);
for (int i = 0;i <= m;i++) c[i] = -1;
build(1, 0, s - 1, 0, 1);
if (n == s) c[A.back()] = 0;
else y[s - 2] = 0;
// for (int i = 0;i <= m;i++) cout <<i << ' '<< c[i]<< endl;
// for (int i = 0;i < s - 1;i++) cout << i + 1<< ' '<< x[i] << ' '<< y[i]<< endl;
answer(c, x, y);
}
# | 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... |