QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#444774#8525. Mercenariesucup-team1198#TL 3750ms354284kbC++204.8kb2024-06-15 21:15:152024-06-15 21:15:15

Judging History

你现在查看的是最新测评结果

  • [2024-06-15 21:15:15]
  • 评测
  • 测评结果:TL
  • 用时:3750ms
  • 内存:354284kb
  • [2024-06-15 21:15:15]
  • 提交

answer

#include <map>
#include <set>
#include <array>
#include <cmath>
#include <deque>
#include <bitset>
#include <random>
#include <string>
#include <vector>
#include <cassert>
#include <complex>
#include <iomanip>
#include <iostream>
#include <algorithm>
#include <unordered_map>
#include <unordered_set>

using namespace std;

#define int int64_t

struct Vector {
  int x;
  int y;

  Vector(int x = 0, int y = 0): x(x), y(y) {}
};

Vector operator-(Vector a, Vector b) {
  return {a.x - b.x, a.y - b.y};
}

Vector operator+(Vector a, Vector b) {
  return {a.x + b.x, a.y + b.y};
}

int operator*(Vector a, Vector b) {
  return a.x * b.x + a.y * b.y;
}

int operator%(Vector a, Vector b) {
  return a.x * b.y - a.y * b.x;
}

int sgn(Vector a, Vector b) {
  __int128 res = a.x * b.y - a.y * b.x;
  if (res < 0) return -1;
  if (res == 0) return 0;
  return 1;
}

bool operator<(Vector a, Vector b) {
  if (a.x == b.x) {
    return a.y > b.y;
  }
  return a.x < b.x;
}

vector<Vector> operator+(const vector<Vector>& a, const vector<Vector>& b) {
  vector<Vector> res;
  res.push_back(a[0] + b[0]);
  int ia = 1, ib = 1;
  while (ia < (int)a.size() || ib < (int)b.size()) {
    if (ia == (int)a.size()) {
      res.push_back(res.back() + b[ib] - b[ib - 1]);
      ++ib;
    } else if (ib == (int)b.size()) {
      res.push_back(res.back() + a[ia] - a[ia - 1]);
      ++ia;
    } else if ((a[ia] - a[ia - 1]) % (b[ib] - b[ib - 1]) < 0) {
      res.push_back(res.back() + a[ia] - a[ia - 1]);
      ++ia;
    } else {
      res.push_back(res.back() + b[ib] - b[ib - 1]);
      ++ib;
    }
  }
  return res;
}

vector<Vector> hull_sorted(const vector<Vector>& a) {
  vector<Vector> st;
  int sz = 0;
  for (Vector p : a) {
    while (sz >= 2 && sgn((p - st[sz - 1]), (st[sz - 1] - st[sz - 2])) <= 0) {
      st.pop_back();
      --sz;
    }
    st.push_back(p);
    ++sz;
  }
  return st;
}

vector<Vector> unite(const vector<Vector>& a, const vector<Vector>& b) {
  vector<Vector> c;
  merge(a.begin(), a.end(), b.begin(), b.end(), back_inserter(c));
  return hull_sorted(c);
}

const int MAXN = 2e5 + 100;
Vector hero[MAXN];
vector<Vector> shop[MAXN];
vector<Vector> tr_shop[MAXN * 4];
vector<Vector> tr_hero[MAXN * 4];

void build(int v, int vl, int vr) {
  if (vr - vl == 1) {
    sort(shop[vl].begin(), shop[vl].end());
    tr_shop[v] = hull_sorted(shop[vl]);
    vector<Vector> h = {hero[vl]};
    tr_hero[v] = h + tr_shop[v];
    return;
  }
  int vm = (vl + vr) / 2;
  build(v * 2, vl, vm);
  build(v * 2 + 1, vm, vr);
  tr_shop[v] = tr_shop[v * 2] + tr_shop[v * 2 + 1];
  tr_hero[v] = unite(tr_hero[2 * v] + tr_shop[2 * v + 1], tr_hero[2 * v + 1]);
}

int norm(int x, int n) {
  return x >= n ? x - n : x;
}

int reduce(int x, int n) {
  while (x < 0) x += n;
  return x;
}

int get_tan(Vector v, const vector<Vector>& p) {
  int i = 0;
  int k = 0;
  int n = p.size();
  while ((1 << k) < n) ++k;
  while (k >= 0) {
    int i1 = norm((i + (1 << k)), n);
    int i2 = reduce((i - (1 << k)), n);
    if (v * p[i1] > v * p[i]) i = i1;
    if (v * p[i2] > v * p[i]) i = i2;
    --k;
  }
  return p[i] * v;
}

int get_pref(int v, int vl, int vr, int r, Vector dir) {
  if (r <= vl) return 0;
  if (r >= vr) {
    return get_tan(dir, tr_shop[v]);
  }
  int vm = (vl + vr) / 2;
  int res1 = get_pref(v * 2, vl, vm, r, dir);
  int res2 = get_pref(v * 2 + 1, vm, vr, r, dir);
  return res1 + res2;
}

int get_last(int v, int vl, int vr, int r, Vector dir, int c) {
  if (r <= vl || get_tan(dir, tr_hero[v]) < c) return -1;
  if (vr - vl == 1) return vl;
  /// cerr << v << " " << vl << " " << vr << endl;
  int vm = (vl + vr) / 2;
  int res = get_last(v * 2 + 1, vm, vr, r, dir, c);
  if (res != -1) return res;
  c -= get_pref(v * 2 + 1, vm, vr, r, dir);
  return get_last(v * 2, vl, vm, r, dir, c);
}

istream& operator>>(istream& in, Vector& v) {
  in >> v.x >> v.y;
  return in;
}


signed main() {
  ios::sync_with_stdio(false);
  cin.tie(0);
  cout.tie(0);

  int n;
  cin >> n;
  for (int i = 0; i < n - 1; ++i) {
    cin >> hero[i];
    int sz;
    cin >> sz;
    shop[i].resize(sz);
    for (Vector& v : shop[i]) {
      cin >> v;
    }
  }
  cin >> hero[n - 1];
  build(1, 0, n - 1);
  /// cerr << "built" << endl; 

  int q;
  cin >> q;
  while (q--) {
    int ind, c;
    Vector dir;
    cin >> ind >> dir >> c;
    --ind;
    /// cerr << ind << " " << c << endl;
    if (dir * hero[ind] >= c) {
      cout << ind + 1 << "\n";
      continue;
    }
    /// cerr << "start" << endl;
    int res = get_last(1, 0, n - 1, ind, dir, c);
    /// cerr << "end" << endl;
    if (res == -1) {
      cout << "-1\n";
    } else {
      cout << res + 1 << "\n";
    }
  }

  
  return 0;
}

详细

Test #1:

score: 100
Accepted
time: 3ms
memory: 8792kb

input:

3
1 1
2 1 2 1 2
3 2
5 1 5 4 3 3 4 5 1 1 2
4 5
12
1 1 1 1
2 1 1 1
3 1 1 1
3 1 1 9
3 2 2 20
3 1 2 18
3 1 2 19
3 1 2 20
3 0 1 8
2 1 0 4
2 1 0 3
2 1 0 2

output:

1
2
3
3
2
2
1
-1
1
-1
2
2

result:

ok 12 numbers

Test #2:

score: 0
Accepted
time: 3ms
memory: 8572kb

input:

2
47 11
1 98 25
9 90
10
1 32 28 1811
2 17 44 4114
1 36 88 2661
2 79 33 3681
1 53 26 2778
2 59 20 2332
2 63 45 4616
2 72 11 10835
1 13 28 919
2 16 59 4445

output:

1
-1
-1
2
-1
1
2
1
1
2

result:

ok 10 numbers

Test #3:

score: 0
Accepted
time: 0ms
memory: 7672kb

input:

3
87 42
5 69 12 82 79 10 88 45 51 40 3
18 6
5 73 100 58 41 40 88 54 5 40 98
31 63
100
3 32 13 1811
1 51 21 5318
1 32 5 2994
2 77 51 19184
2 78 60 1763
1 10 1 913
1 22 51 4057
1 2 5 385
2 50 15 989
2 65 53 1488
1 49 82 7708
2 33 90 1133
1 23 33 3388
1 92 36 9516
3 39 61 10014
2 43 55 1103
2 48 38 127...

output:

3
1
1
1
2
-1
-1
-1
2
2
-1
2
-1
1
2
2
-1
3
2
2
3
1
1
1
-1
1
1
1
3
1
-1
1
-1
1
2
1
2
1
1
1
1
1
-1
1
-1
-1
1
1
-1
-1
1
1
2
1
1
-1
2
-1
1
1
1
1
3
1
2
3
2
2
1
1
-1
1
1
3
1
1
1
3
2
1
1
2
1
2
1
2
1
-1
-1
-1
1
2
1
1
-1
-1
1
3
2
2

result:

ok 100 numbers

Test #4:

score: 0
Accepted
time: 141ms
memory: 15736kb

input:

2
309248041 338995438
500000 1235 4866 1931 3652 1921 258 545 587 3001 542 3074 1694 4944 206 3217 3135 2388 4791 1890 3281 3840 4614 4491 1339 4660 1708 2225 3199 736 1306 4175 4652 906 3509 2571 1578 50 981 402 4975 2730 2198 4546 3120 40 815 2492 518 2102 2651 1018 3996 1764 808 3934 4312 1981 40...

output:

2
1
-1
2
2
2
1
1
2
-1
2
2
1
1
2
1
2
2
1
2
2
1
-1
-1
1
-1
2
-1
1
2
1
1
1
1
-1
1
-1
-1
-1
1
2
2
1
1
1
2
-1
-1
1
-1
1
2
-1
1
2
1
2
2
-1
2
1
2
2
-1
2
2
-1
2
1
2
1
-1
-1
1
1
-1
2
1
2
2
1
1
1
1
2
2
-1
-1
1
2
2
-1
2
-1
-1
-1
1
2
1
1
2
2
1
-1
-1
2
2
2
1
-1
1
2
2
-1
1
-1
-1
-1
1
2
1
2
1
-1
-1
1
2
2
-1
2
2
2
...

result:

ok 200000 numbers

Test #5:

score: 0
Accepted
time: 349ms
memory: 155116kb

input:

200000
999999511 993051669
2 5000 5000 5000 5000
1000000000 1000000000
3 5000 5000 5000 5000 5000 5000
995868520 999999999
2 5000 5000 5000 5000
660478427 999992996
3 5000 5000 5000 5000 5000 5000
999999979 999999998
2 5000 5000 5000 5000
861450412 989532141
3 5000 5000 5000 5000 5000 5000
949861679...

output:

145800
198491
112658
29436
38091
122582
7727
87686
192036
97288
60184
836
39235
158331
121422
117149
189664
153018
181334
56603
69911
173097
165342
124250
103223
110099
177817
11459
37052
28918
57236
143793
19234
10313
75590
6597
18202
176357
102394
179685
5171
162359
72023
56758
88764
17257
100583
...

result:

ok 200000 numbers

Test #6:

score: 0
Accepted
time: 0ms
memory: 8316kb

input:

20
1538 3628
4 2423 3790 3127 3961 2614 3582 2016 4789
1441 276
3 2518 253 4221 265 3236 2574
1668 3370
4 4489 3533 4501 2177 1067 2337 2765 1480
1179 1926
3 4922 2537 1477 653 325 444
3964 2924
2 3415 4463 822 3257
210 4068
2 1969 167 1978 3712
2067 540
4 1560 2211 4050 4196 442 2279 442 2448
2962 ...

output:

5
14
5
1
2
3
6
-1
8
7
2
11
1
8
8
3
3
13
4
5

result:

ok 20 numbers

Test #7:

score: 0
Accepted
time: 3ms
memory: 7444kb

input:

66
121 3727
2 1379 2036 975 1594
205 708
2 523 2978 176 2924
2528 440
4 3182 2078 1340 2166 1563 447 1076 157
3242 2859
5 2029 4660 2789 1593 4534 4137 921 3966 3440 1964
1503 3975
3 1354 3815 825 4981 1710 2692
858 2524
3 3395 3523 2184 4115 4043 3518
2610 731
3 3735 2799 442 1348 3101 2847
4306 14...

output:

9
12
20
-1
3
18
23
2
4
48
13
-1
8
38
8
28
7
1
8
51
4
9
10
10
3
24
14
5
19
2
33
3
45
5
4
29
5
23
24
36
24
-1
9
4
26
1
2
1
46
37
8
2
20
2
1
27
26
41
5
32
3
37
-1
7
43
2

result:

ok 66 numbers

Test #8:

score: 0
Accepted
time: 4ms
memory: 8340kb

input:

200
2768 3191
1 482 2676
4032 1626
1 1313 472
117 4314
3 1745 3269 1723 1603 1307 2675
2553 172
5 1678 868 246 2764 3746 3346 3650 317 3675 3877
2425 2618
2 1883 4174 4213 1781
3099 3645
1 4652 2962
1910 1338
3 4530 2328 2576 3373 3 1145
1887 1331
4 459 736 139 3184 550 31 740 3134
3488 2965
3 2097 ...

output:

57
85
59
36
24
39
5
4
81
49
23
107
104
39
62
49
3
156
25
64
13
92
16
62
20
104
13
26
66
61
109
56
1
32
7
37
14
9
10
136
20
7
2
129
149
109
29
15
51
18
80
107
6
20
50
27
111
-1
115
16
10
88
21
12
88
1
2
31
72
10
67
68
5
6
1
80
120
73
187
26
17
2
64
125
-1
43
4
10
72
13
129
45
118
54
27
56
100
56
27
3...

result:

ok 200 numbers

Test #9:

score: 0
Accepted
time: 6ms
memory: 8572kb

input:

666
2648 877
2 170 1622 4953 3255
18 2631
2 2355 1545 3734 1505
724 216
1 1944 1090
3733 2918
3 3393 1081 3478 4932 2001 501
3399 1829
3 4189 4125 1957 1754 2904 3622
4643 554
4 229 4356 3777 1315 4848 2584 1232 2718
4096 1924
2 892 1180 3500 2905
1759 1274
4 3950 1096 1779 2159 1617 1856 3182 2679
...

output:

466
198
247
228
66
306
101
147
11
480
35
354
59
225
76
20
314
84
272
2
315
13
6
4
212
430
28
290
339
121
125
4
21
362
254
19
77
456
69
27
62
6
269
100
68
4
396
1
58
377
203
100
94
162
188
151
48
4
377
277
242
274
217
167
45
24
116
291
263
305
112
183
225
5
107
120
210
56
50
140
4
192
165
250
303
77
...

result:

ok 666 numbers

Test #10:

score: 0
Accepted
time: 12ms
memory: 9952kb

input:

2000
2883 1742
3 281 1763 9 3931 3350 1572
1611 462
3 983 1286 1874 1928 4279 857
3773 1341
2 3861 4264 733 4060
1220 1451
3 2753 624 4520 2881 2051 1614
1406 2742
5 2857 2152 4349 495 3552 1319 4118 4269 3286 2235
4028 1138
4 2209 4188 1788 4226 517 2932 4067 3746
3105 2345
2 731 2039 1927 1275
137...

output:

1
210
42
101
386
26
68
202
806
352
362
29
559
52
1334
741
260
565
1041
85
220
67
448
194
1110
179
843
625
453
1055
641
691
79
145
869
10
40
8
60
134
1108
179
560
773
1748
452
469
1165
515
456
602
366
781
15
5
269
459
42
509
1046
339
1064
923
944
84
76
499
-1
1345
1051
44
2
1406
680
1726
326
32
96
85...

result:

ok 2000 numbers

Test #11:

score: 0
Accepted
time: 30ms
memory: 13192kb

input:

6666
2741 2461
3 526 4139 3060 2030 2766 3316
653 3631
1 4366 67
2628 3849
2 2449 2607 1617 68
3001 126
1 4561 4505
3166 3358
3 4322 1581 957 756 865 3540
1442 2226
4 4137 2789 2636 3371 3383 60 620 2488
550 3026
5 1285 3936 4074 4144 3933 3572 825 2255 55 796
4544 1791
3 1459 863 4284 3153 1674 122...

output:

46
1772
1912
2973
15
5358
3822
649
679
4265
1819
3808
783
1759
1426
2865
1820
11
168
209
4207
3606
1234
4049
576
1052
1514
86
191
712
4475
2262
223
1513
3483
3719
5287
4028
200
2063
241
1217
3043
622
955
5463
1806
337
855
2275
2962
164
3955
1673
353
2999
4622
2701
601
1999
933
35
2004
3380
64
776
27...

result:

ok 6666 numbers

Test #12:

score: 0
Accepted
time: 149ms
memory: 30276kb

input:

20000
1186 1182
1 2552 75
370 1750
2 1657 2841 3265 719
3481 2197
2 4047 16 277 1224
593 97
4 358 4602 1995 1679 1888 4757 4297 2320
3187 3062
2 2394 2756 3744 3166
467 261
3 3385 2572 4595 719 3514 1870
178 3985
4 1004 1799 4259 2920 1155 2664 4064 3732
385 2278
2 1784 4561 1022 1281
3907 2706
1 39...

output:

629
10461
7163
711
6127
3895
1990
1492
3117
2779
3930
428
10729
938
1012
541
6697
3517
4567
6669
285
10601
15453
11721
2
633
535
288
13293
15510
13541
1550
6895
6138
5565
6672
93
1621
6958
4345
4669
6546
11999
74
4152
7192
3334
2423
1982
1884
1956
3630
4614
1777
1826
6986
9
2318
8064
303
3082
1287
1...

result:

ok 20000 numbers

Test #13:

score: 0
Accepted
time: 407ms
memory: 53172kb

input:

40000
1322 4123
3 1729 4107 1325 1826 756 1338
2281 2223
4 3251 2045 4210 3298 3405 2626 2449 2539
332 4779
2 4329 2666 4605 253
501 2829
3 2908 2017 3694 4704 3794 3259
2231 3518
3 984 1800 2861 888 1137 4675
16 2796
5 3690 143 3763 3138 663 298 174 2769 3953 1526
1320 1584
2 3472 4857 1781 4871
39...

output:

117
10439
9881
3959
6978
234
11142
6493
28076
4122
9986
11628
20104
10580
20548
21044
2006
7256
14386
17260
7249
2969
18038
3722
1976
1080
19587
1804
108
2722
1370
554
2415
13413
4430
4743
1490
21
15752
14857
31955
1250
10259
10460
1775
996
51
13148
13819
22536
2861
2321
69
10517
4007
10082
13384
65...

result:

ok 40000 numbers

Test #14:

score: 0
Accepted
time: 784ms
memory: 86504kb

input:

66666
3910 403
2 475 1131 939 2976
3588 2717
3 4367 2516 4737 4629 351 2278
879 4121
1 4665 4982
1229 3257
3 4774 412 2628 3043 2537 4632
4102 764
4 365 1999 1340 1043 725 184 1366 464
1632 462
1 3678 1459
1472 3921
2 2218 3124 1193 4188
587 4637
3 663 2801 3365 1486 4024 2027
464 4849
2 3627 726 18...

output:

18005
6802
4402
63081
12216
1997
3852
2251
25870
25581
25907
172
21566
7609
432
11729
6583
7984
5659
8279
2295
27118
11619
4499
18976
2789
64962
7114
17828
4100
9093
2201
164
25433
799
9329
1573
5677
1802
6594
16903
3261
10135
4868
1878
8830
43109
33459
478
18129
21607
24469
102
1169
18060
11070
145...

result:

ok 66666 numbers

Test #15:

score: 0
Accepted
time: 1419ms
memory: 120712kb

input:

100000
2766 3928
1 801 4090
1696 1887
2 2478 338 4886 2028
4449 473
2 4009 2510 587 962
3272 2216
2 1422 457 2248 2264
1634 2781
1 463 1296
292 433
4 406 4396 99 4408 64 1583 2977 4428
2628 1270
2 2431 4144 2898 2133
1412 4349
2 2756 3515 1551 3118
2461 1056
1 3027 4519
3257 940
2 1241 1252 4920 465...

output:

71
44948
26956
58728
15513
11202
23070
1708
936
2159
10979
37052
26887
7507
24943
1182
12837
6822
55436
8472
45797
40278
23445
1702
5051
50219
7096
1063
18284
379
52305
25792
17832
12078
11885
53278
8544
1148
6362
10594
13108
66927
44308
65930
74953
13065
1153
3085
443
9498
12671
10554
29519
43697
3...

result:

ok 100000 numbers

Test #16:

score: 0
Accepted
time: 3750ms
memory: 240648kb

input:

200000
870 4638
6 4716 1571 845 599 943 4354 4102 2994 4706 3121 1579 4190
4305 2436
2 2767 1501 3629 98
3824 1262
1 2748 2558
1723 166
3 4457 4290 1253 3994 4266 4934
2021 1195
1 2736 2682
2407 484
3 1531 3959 3257 2154 123 1106
2441 674
1 2450 2914
3057 3536
3 1533 1051 1507 2518 3773 2867
3622 15...

output:

157843
25378
57229
10046
64593
20854
163253
59732
56538
978
2512
108129
2903
69944
5488
98723
14617
165726
23353
409
57829
79874
123834
4583
8613
3554
33478
12378
19599
94577
5555
76752
95569
1701
16813
181
12645
2668
50296
58364
79228
918
22141
93190
36225
119304
31816
46997
33449
60084
65843
24284...

result:

ok 200000 numbers

Test #17:

score: 0
Accepted
time: 3090ms
memory: 208872kb

input:

131071
139764 478870
4 4782 1547 2947 4953 3336 3508 4282 3928
40955 209792
5 4214 616 86 4104 3099 4024 3994 1365 1027 4531
231530 91516
3 3085 3413 2092 3701 2933 4226
40015 431714
1 4764 4756
327678 328274
2 4882 3819 1767 4068
97093 266868
3 879 2008 2107 2988 4120 2907
261491 97456
2 4192 4053 ...

output:

27274
6408
588
102723
58669
20816
8478
46672
42410
73733
844
107573
39190
30387
45336
33923
41985
27314
20278
39399
46315
35755
42380
5920
113412
109707
74826
19148
18707
73650
11681
74360
66765
4404
3629
19265
14140
35353
18059
32351
696
69704
33963
1410
9113
43952
40178
6935
4132
84180
22997
24766...

result:

ok 200000 numbers

Test #18:

score: 0
Accepted
time: 2523ms
memory: 207064kb

input:

131072
6223 460632
6 2483 2393 2842 257 3518 3179 4691 3866 4420 4839 1231 2273
247781 211555
2 276 3122 4545 3262
425398 177601
4 971 679 2764 2174 1464 3566 3098 4846
232356 163195
2 4469 1931 4889 1379
386550 88052
4 3242 4291 3446 1609 4751 2330 2543 2225
452519 156503
4 3790 520 1149 647 1466 3...

output:

6208
13417
58680
29635
28147
58019
9452
11259
55255
52801
18425
23854
60997
23540
70470
72642
43355
4178
64018
35442
8237
7410
22214
40424
63910
47446
19637
53405
83758
6064
10504
26267
80024
8891
26029
19848
23749
22185
9446
97454
57990
50674
3543
9055
37796
38089
54665
14909
20941
51503
59197
9677...

result:

ok 200000 numbers

Test #19:

score: 0
Accepted
time: 2549ms
memory: 207936kb

input:

131073
316493 134226
3 780 3985 4704 2047 416 1078
48008 126287
6 4988 1028 3318 3341 3383 4549 4241 275 3964 3949 2420 2420
335453 237601
2 1866 924 3852 35
9423 207118
5 1422 2957 1647 1127 4449 4421 2871 2912 401 538
246824 114850
2 3199 1999 2198 4479
415809 123678
3 2256 360 3457 2925 1796 1026...

output:

53510
29593
17978
8358
34248
40865
43104
90096
6781
55563
71447
6624
33577
41420
9038
103039
38104
73338
114013
53095
66427
36616
77104
46399
83191
56991
24673
19483
17851
6718
15584
7777
277
20657
13937
74652
8870
99630
24045
34743
47382
77338
55563
18271
16144
55236
12782
857
39012
17686
16225
157...

result:

ok 200000 numbers

Test #20:

score: 0
Accepted
time: 2884ms
memory: 240368kb

input:

199901
3293 2284
3 1171 2655 3120 2577 2805 4312
3025 3891
3 3723 1531 4540 4479 1421 4008
4210 1811
1 2492 2142
3204 292
4 2776 4278 695 4035 4569 1257 2269 1254
1459 81
2 3560 2675 1780 597
2988 2959
6 1392 4017 10 1770 351 1029 2078 1664 1718 4192 2599 3109
2279 155
4 3643 1851 2643 2128 3610 380...

output:

4230
137033
62455
130749
5941
16398
40711
15337
2635
7212
72282
7921
29478
2813
59569
13644
58578
6631
94895
140488
17258
37640
195731
76075
53058
114476
63415
65345
35469
86745
122531
46090
66377
57034
8757
2011
102224
71022
24914
5094
2984
146398
27257
47641
44643
114
45395
667
45343
55808
85128
7...

result:

ok 199990 numbers

Test #21:

score: 0
Accepted
time: 3295ms
memory: 240952kb

input:

200000
2543 2408
1 4912 368
1981 3459
3 910 3485 4574 2614 2736 2196
953 4370
4 1174 483 1103 515 4395 3184 4616 3927
1485 4521
3 1581 3154 3114 2121 4816 162
2234 1377
1 339 289
2921 1761
1 3350 123
848 3567
2 4505 1444 34 194
4038 23
1 543 1618
1274 3140
1 4579 4286
1805 2514
2 27 2089 1985 2267
1...

output:

55056
5065
129558
48887
7737
6893
70544
20543
20065
128053
22138
2594
63038
75004
39979
74728
94906
50369
1269
32896
59693
6927
8387
83890
63662
53547
88114
12797
49267
35553
62420
88476
43383
583
47258
24940
139951
6193
139637
142146
46322
35506
139053
41925
13909
59337
7
146270
66669
1077
4091
3
2...

result:

ok 199982 numbers

Test #22:

score: 0
Accepted
time: 3269ms
memory: 238880kb

input:

199900
78690 820471
3 4242 531 1591 1243 639 701
350077 537673
2 2906 1644 1996 2563
519283 295902
2 1692 1820 180 4879
208195 417170
1 3597 2277
282917 929980
1 798 517
615590 225385
2 4024 1291 152 4632
86541 683217
3 314 4423 2362 3917 2935 1967
33589 406147
3 4094 4478 3069 234 4285 979
454586 2...

output:

15359
114877
149266
58974
118321
40999
148940
532
14483
64287
8866
22654
129942
61632
109711
3927
153100
71435
2177
30441
28073
86539
45196
68783
82972
80262
65262
84238
117008
1087
17884
128527
48712
25016
103846
39000
61746
76189
8023
7813
10502
49894
105981
46505
9256
31425
154264
5667
45148
1006...

result:

ok 200000 numbers

Test #23:

score: 0
Accepted
time: 3281ms
memory: 239420kb

input:

199987
212495 690296
3 2211 2384 3463 1623 4397 98
788317 313858
2 1218 3653 460 2398
276899 302136
3 960 3279 3790 1492 2930 2590
592888 466734
1 1938 3102
232542 208827
3 2408 4364 153 2513 4528 3130
336342 363920
1 2451 916
553994 822203
2 505 2680 1524 2648
477482 80133
1 3366 2194
170616 431748...

output:

2848
8201
50339
6660
16767
110662
3191
24591
66905
77921
49986
30208
68132
3655
32728
38291
127466
175067
98798
14339
34081
68281
18756
2527
54881
19947
9943
22880
36424
107904
98360
37827
51983
9476
4691
47778
170101
6580
142774
86794
11847
22791
52841
54793
30466
150293
61105
16792
21133
46137
404...

result:

ok 199936 numbers

Test #24:

score: 0
Accepted
time: 3649ms
memory: 238836kb

input:

200000
607780 128071
3 4280 2827 4926 1431 1610 1681
718674 662164
4 3178 467 1478 1233 3442 3952 4196 2133
641607 7028
3 4460 3173 3768 3818 1884 232
448230 512426
4 1684 4065 1980 4706 1590 3175 2418 1606
605366 235823
3 3754 1702 4298 4142 2545 1964
692258 609171
1 189 4286
52916 189132
3 4892 84...

output:

7675
388
23524
40366
67485
3971
77425
2612
177284
73819
87300
86224
14970
18357
14912
88059
15023
97386
142963
8550
24228
39238
27597
132898
53228
65770
11733
66830
57708
97106
7567
5356
2649
28520
479
51533
125151
18769
126176
13509
50777
90839
9528
56250
159592
33753
138984
62105
69918
229
13267
6...

result:

ok 199975 numbers

Test #25:

score: 0
Accepted
time: 3039ms
memory: 228744kb

input:

199953
142561117 474175298
4 3719 154 2429 4996 2633 2432 4560 4149
141373697 22414249
3 2448 1149 4026 3041 1232 161
126914209 400530096
4 1486 3925 245 212 1811 2487 3272 1295
327219634 328108615
2 3275 757 351 627
9347529 468040920
5 1531 2208 4180 826 3699 2436 980 4886 2864 4444
62450112 451004...

output:

75447
12244
122033
124150
78605
80776
70046
46001
4905
3889
11646
12216
71533
166040
55718
142972
73624
16898
40056
12319
153304
69143
56748
47703
80338
70788
17686
60233
33504
83809
77704
4841
17081
11683
37766
51658
85399
17202
105691
48602
82006
5722
27631
87399
75189
2963
123766
2072
112062
5369...

result:

ok 199919 numbers

Test #26:

score: 0
Accepted
time: 2798ms
memory: 227956kb

input:

200000
59874959 283731044
3 638 1092 907 2892 4303 2533
223263132 50393364
1 2195 2223
95200195 145583768
3 2610 793 1421 3193 4707 639
197055310 294066377
1 741 3992
118585604 219943492
2 4815 3612 3236 1887
218563794 25623048
1 917 4569
44315832 264892800
2 2464 2670 4637 2845
97726329 154588982
1...

output:

6388
81686
31209
79809
65193
90639
3781
97032
66711
6756
22791
4381
29561
9743
17542
48047
27677
61695
12712
57494
52435
109251
85407
33906
17542
130393
33119
184388
40557
-1
90503
70517
83217
13297
9900
9027
25308
117742
69266
2966
111482
46336
147358
150891
147172
40477
110331
79050
30430
19683
87...

result:

ok 200000 numbers

Test #27:

score: 0
Accepted
time: 2917ms
memory: 230096kb

input:

200000
246174057 382791134
3 3880 3106 3734 711 4015 2302
20079721 484929831
1 2061 997
223865187 355513072
4 879 4541 3235 1301 3105 1236 1630 4533
142533043 269545254
2 4245 1903 3821 2381
393154979 154666975
4 2984 1783 1491 1837 2285 4545 374 4755
59420490 483179350
4 1994 854 457 2141 4398 336 ...

output:

27859
123483
15393
152454
47896
1201
33614
41017
185257
95292
138407
88769
112740
116135
-1
133322
65051
14877
75604
91209
58904
26078
101227
32710
2725
9863
162222
1637
68150
29277
81768
4572
60685
98204
175051
112947
69266
73996
107101
8338
5856
70244
144471
147576
59688
19088
60623
93479
3401
485...

result:

ok 199963 numbers

Test #28:

score: 0
Accepted
time: 3650ms
memory: 354284kb

input:

200000
85 80
2 883 707 58 1513
1767 0
1 3087 0
808 3948
4 192 1419 1599 27 597 1021 850 771
224 6116
4 2514 1873 2065 2312 1280 3074 4021 342
711 9955
1 111 28
229 10555
1 487 170
20 11396
4 13 1262 1079 211 774 515 256 1024
12608 311
3 1701 891 854 1750 104 2483
14710 792
2 380 9 126 266
15847 21
6...

output:

44686
8476
62791
8712
70714
-1
19902
-1
81267
161132
146323
34841
22913
29635
63141
97338
3992
16255
40877
139469
123399
174831
-1
192581
156890
41550
99146
149
116506
70649
42747
99581
10218
58946
137726
1937
7923
160633
65409
-1
93331
36229
12492
91800
142342
183775
62909
72739
163683
21518
69037
...

result:

ok 200000 numbers

Test #29:

score: -100
Time Limit Exceeded

input:

200000
18 635
1 21 474
682 465
2 907 608 1414 99
272 2386
2 910 298 167 1042
3736 129
1 298 136
148 4148
1 409 271
4960 16
1 1229 177
14 6351
2 19 1709 597 1126
7613 484
1 118 187
8192 205
2 5 957 846 119
1067 8302
1 725 153
27 10200
2 455 1078 1372 172
11741 36
1 177 37
400 11570
2 1479 142 688 943...

output:

4809
113219
19270
22649
-1
28510
46480
-1
-1
120187
5286
30255
175327
-1
35132
48373
-1
99785
22171
28
-1
-1
35212
59741
820
117119
53211
-1
-1
-1
19352
62556
26264
38722
-1
-1
151132
-1
17649
43686
52991
50944
17571
147761
72757
28818
43190
49005
-1
41258
81990
2708
163827
19888
7358
-1
46781
-1
17...

result: