#include "routers.h"
#ifdef MINA
#include "grader.cpp"
#endif
#include <bits/stdc++.h>
using namespace std;
vector<int> ans, dist;
void bs(int s, int e, int a, int b) {
if (a > b) return;
if (e - s == b - a) {
for (int i = s; i <= e; i++) {
dist.push_back(i);
}
return;
}
if (s + 1 == e) {
if (use_detector(e) == a) {
dist.push_back(e);
} else {
dist.push_back(s);
}
return;
}
int m = (s + e) / 2;
int hi = use_detector(m);
bs(s, m - 1, a, hi - 1);
bs(m, e, hi, b);
}
vector<int> find_routers(int l, int n, int q) {
bs(0, l, 0, n - 2);
ans.resize(n);
ans[0] = 0;
for (int i = 1; i < n; i++)
{
ans[i] = 2 * dist[i - 1] - ans[i - 1];
}
return ans;
}
I2luY2x1ZGUgInJvdXRlcnMuaCIKI2lmZGVmIE1JTkEKI2luY2x1ZGUgImdyYWRlci5jcHAiCiNlbmRpZgojaW5jbHVkZSA8Yml0cy9zdGRjKysuaD4KdXNpbmcgbmFtZXNwYWNlIHN0ZDsKCnZlY3RvcjxpbnQ+IGFucywgZGlzdDsKCnZvaWQgYnMoaW50IHMsIGludCBlLCBpbnQgYSwgaW50IGIpIHsKICAgIGlmIChhID4gYikgcmV0dXJuOwogICAgaWYgKGUgLSBzID09IGIgLSBhKSB7CiAgICAgICAgZm9yIChpbnQgaSA9IHM7IGkgPD0gZTsgaSsrKSB7CiAgICAgICAgICAgIGRpc3QucHVzaF9iYWNrKGkpOwogICAgICAgIH0KICAgICAgICByZXR1cm47CiAgICB9CiAgICBpZiAocyArIDEgPT0gZSkgewogICAgICAgIGlmICh1c2VfZGV0ZWN0b3IoZSkgPT0gYSkgewogICAgICAgICAgICBkaXN0LnB1c2hfYmFjayhlKTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBkaXN0LnB1c2hfYmFjayhzKTsKICAgICAgICB9CiAgICAgICAgcmV0dXJuOwogICAgfQogICAgaW50IG0gPSAocyArIGUpIC8gMjsKICAgIGludCBoaSA9IHVzZV9kZXRlY3RvcihtKTsKICAgIGJzKHMsIG0gLSAxLCBhLCBoaSAtIDEpOwogICAgYnMobSwgZSwgaGksIGIpOwp9Cgp2ZWN0b3I8aW50PiBmaW5kX3JvdXRlcnMoaW50IGwsIGludCBuLCBpbnQgcSkgewogICAgYnMoMCwgbCwgMCwgbiAtIDIpOwogICAgYW5zLnJlc2l6ZShuKTsKICAgIGFuc1swXSA9IDA7CiAgICBmb3IgKGludCBpID0gMTsgaSA8IG47IGkrKykKICAgIHsKICAgICAgICBhbnNbaV0gPSAyICogZGlzdFtpIC0gMV0gLSBhbnNbaSAtIDFdOwogICAgfQogICAgcmV0dXJuIGFuczsKfQo=