// @check-accepted: examples NQsmall Qsmall Bsmall full
#include <bits/stdc++.h>
using namespace std;
const int max_size = 2e5 + 100, INF = 2e9;
int v[max_size], dist[21][max_size];
vector<int> adj[max_size];
void bfs(int bit, int start) {
queue<int> q;
q.push(start);
dist[bit][start] = 1;
while (!q.empty()) {
int nod = q.front();
q.pop();
for (auto nei : adj[nod]) {
if (dist[bit][nei] == INF) {
dist[bit][nei] = dist[bit][nod] + 1;
q.push(nei);
}
}
}
}
int main() {
ios_base::sync_with_stdio(false);
cin.tie(0);
int n, q;
cin >> n >> q;
for (int i = 1; i <= n; i++) {
cin >> v[i];
for (int e = 0; e <= 20; e++) {
if ((v[i] & (1 << e)) != 0) {
adj[i].push_back(n + e + 1);
adj[n + e + 1].push_back(i);
}
}
}
for (int i = 1; i <= n + 21; i++) {
for (int j = 0; j <= 20; j++) {
dist[j][i] = INF;
}
}
for (int j = 0; j <= 20; j++) {
bfs(j, n + j + 1);
}
while (q--) {
int ans = INF, x, y;
cin >> x >> y;
for (int j = 0; j <= 20; j++) {
if (v[x] & (1 << j)) ans = min(ans, dist[j][y]);
}
cout << (ans == INF ? -1 : ans / 2) << '\n';
}
cout << '\n';
return 0;
}
Részfeladat | Összpont | Teszt | Verdikt | Idő | Memória | ||
---|---|---|---|---|---|---|---|
subtask1 | 0/0 | ||||||
1 | Elfogadva | 4ms | 5176 KiB | ||||
2 | Elfogadva | 6ms | 5176 KiB | ||||
subtask2 | 7/7 | ||||||
3 | Elfogadva | 7ms | 5176 KiB | ||||
4 | Elfogadva | 4ms | 5176 KiB | ||||
5 | Elfogadva | 6ms | 5320 KiB | ||||
6 | Elfogadva | 6ms | 5336 KiB | ||||
7 | Elfogadva | 7ms | 5176 KiB | ||||
8 | Elfogadva | 7ms | 5208 KiB | ||||
9 | Elfogadva | 4ms | 5176 KiB | ||||
10 | Elfogadva | 6ms | 5176 KiB | ||||
11 | Elfogadva | 6ms | 5176 KiB | ||||
12 | Elfogadva | 6ms | 5356 KiB | ||||
13 | Elfogadva | 6ms | 5176 KiB | ||||
subtask3 | 23/23 | ||||||
14 | Elfogadva | 375ms | 31412 KiB | ||||
15 | Elfogadva | 384ms | 31644 KiB | ||||
16 | Elfogadva | 298ms | 31624 KiB | ||||
17 | Elfogadva | 472ms | 35300 KiB | ||||
18 | Elfogadva | 381ms | 37204 KiB | ||||
19 | Elfogadva | 501ms | 38740 KiB | ||||
20 | Elfogadva | 321ms | 29852 KiB | ||||
21 | Elfogadva | 331ms | 30044 KiB | ||||
22 | Elfogadva | 314ms | 30124 KiB | ||||
23 | Elfogadva | 319ms | 30008 KiB | ||||
24 | Elfogadva | 233ms | 35304 KiB | ||||
25 | Elfogadva | 261ms | 35572 KiB | ||||
subtask4 | 21/21 | ||||||
26 | Elfogadva | 217ms | 30464 KiB | ||||
27 | Elfogadva | 206ms | 29604 KiB | ||||
28 | Elfogadva | 214ms | 30236 KiB | ||||
29 | Elfogadva | 199ms | 30864 KiB | ||||
30 | Elfogadva | 219ms | 30964 KiB | ||||
31 | Elfogadva | 196ms | 30820 KiB | ||||
32 | Elfogadva | 204ms | 29608 KiB | ||||
33 | Elfogadva | 204ms | 29856 KiB | ||||
34 | Elfogadva | 184ms | 29788 KiB | ||||
35 | Elfogadva | 184ms | 29852 KiB | ||||
subtask5 | 49/49 | ||||||
36 | Elfogadva | 6ms | 5176 KiB | ||||
37 | Elfogadva | 6ms | 5180 KiB | ||||
38 | Elfogadva | 7ms | 5176 KiB | ||||
39 | Elfogadva | 4ms | 5176 KiB | ||||
40 | Elfogadva | 6ms | 5320 KiB | ||||
41 | Elfogadva | 6ms | 5336 KiB | ||||
42 | Elfogadva | 7ms | 5176 KiB | ||||
43 | Elfogadva | 7ms | 5208 KiB | ||||
44 | Elfogadva | 4ms | 5176 KiB | ||||
45 | Elfogadva | 6ms | 5176 KiB | ||||
46 | Elfogadva | 6ms | 5176 KiB | ||||
47 | Elfogadva | 6ms | 5356 KiB | ||||
48 | Elfogadva | 6ms | 5176 KiB | ||||
49 | Elfogadva | 375ms | 31412 KiB | ||||
50 | Elfogadva | 384ms | 31644 KiB | ||||
51 | Elfogadva | 298ms | 31624 KiB | ||||
52 | Elfogadva | 472ms | 35300 KiB | ||||
53 | Elfogadva | 381ms | 37204 KiB | ||||
54 | Elfogadva | 501ms | 38740 KiB | ||||
55 | Elfogadva | 321ms | 29852 KiB | ||||
56 | Elfogadva | 331ms | 30044 KiB | ||||
57 | Elfogadva | 314ms | 30124 KiB | ||||
58 | Elfogadva | 319ms | 30008 KiB | ||||
59 | Elfogadva | 233ms | 35304 KiB | ||||
60 | Elfogadva | 261ms | 35572 KiB | ||||
61 | Elfogadva | 217ms | 30464 KiB | ||||
62 | Elfogadva | 206ms | 29604 KiB | ||||
63 | Elfogadva | 214ms | 30236 KiB | ||||
64 | Elfogadva | 199ms | 30864 KiB | ||||
65 | Elfogadva | 219ms | 30964 KiB | ||||
66 | Elfogadva | 196ms | 30820 KiB | ||||
67 | Elfogadva | 204ms | 29608 KiB | ||||
68 | Elfogadva | 204ms | 29856 KiB | ||||
69 | Elfogadva | 184ms | 29788 KiB | ||||
70 | Elfogadva | 184ms | 29852 KiB | ||||
71 | Elfogadva | 384ms | 31588 KiB | ||||
72 | Elfogadva | 532ms | 32148 KiB | ||||
73 | Elfogadva | 501ms | 31532 KiB | ||||
74 | Elfogadva | 617ms | 39564 KiB | ||||
75 | Elfogadva | 606ms | 37420 KiB | ||||
76 | Elfogadva | 629ms | 38484 KiB | ||||
77 | Elfogadva | 510ms | 38200 KiB | ||||
78 | Elfogadva | 428ms | 30392 KiB | ||||
79 | Elfogadva | 426ms | 30372 KiB | ||||
80 | Elfogadva | 328ms | 30388 KiB | ||||
81 | Elfogadva | 433ms | 30488 KiB | ||||
82 | Elfogadva | 405ms | 36960 KiB | ||||
83 | Elfogadva | 426ms | 37944 KiB | ||||
84 | Elfogadva | 425ms | 37988 KiB |