//
// Created by mihai145 on 16.02.2021.
//
#include <vector>
#include <cmath>
#include "icc.h"
using namespace std;
const int NMAX = 100;
int comp[NMAX + 2];
void run(int N) {
for(int i = 1; i <= N; i++) {
comp[i] = i - 1;
}
for(int c = N; c > 1; c--) {
int log = log2(c);
vector<int> A, B;
for(int bit = 0; bit <= log; bit++) {
vector<int> a, b;
for(int i = 1; i <= N; i++) {
if (comp[i] & (1 << bit))
a.push_back(i);
else
b.push_back(i);
}
int q = query((int)a.size(), (int)b.size(), a.data(), b.data());
if(q) {
A = a;
B = b;
break;
}
}
for(int step = 1; step <= 2; step++) {
while((int)A.size() > 1) {
vector<int> A1, A2;
for(int i = 0; i < (int)A.size(); i++) {
if(i % 2 == 0) {
A1.push_back(A[i]);
} else {
A2.push_back(A[i]);
}
}
int q = query((int)A1.size(), (int)B.size(), A1.data(), B.data());
if(q) {
A = A1;
} else {
A = A2;
}
}
swap(A, B);
}
setRoad(A[0], B[0]);
int cA = comp[A[0]], cB = comp[B[0]];
for(int i = 1; i <= N; i++)
if(comp[i] == cA) {
comp[i] = cB;
}
}
}
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
7 ms |
876 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Correct |
41 ms |
492 KB |
Ok! 549 queries used. |
2 |
Runtime error |
22 ms |
876 KB |
Execution killed with signal 11 |
3 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
60 ms |
876 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
95 ms |
1004 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
59 ms |
876 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |
# |
결과 |
실행 시간 |
메모리 |
Grader output |
1 |
Runtime error |
63 ms |
876 KB |
Execution killed with signal 11 |
2 |
Halted |
0 ms |
0 KB |
- |