QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#806143#9862. AntivirusrgnerdplayerAC ✓290ms48464kbC++2310.2kb2024-12-08 22:22:382024-12-08 22:22:38

Judging History

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

  • [2024-12-08 22:22:38]
  • 评测
  • 测评结果:AC
  • 用时:290ms
  • 内存:48464kb
  • [2024-12-08 22:22:38]
  • 提交

answer

#include <bits/stdc++.h>
using namespace std;

using i64 = long long;

struct HLD {
    int n, cur = 0;
    vector<int> sz, top, dep, par, tin, tout, seq;
    vector<vector<int>> adj;
    HLD(int n) : n(n), sz(n, 1), top(n), dep(n), par(n), tin(n), tout(n), seq(n), adj(n) {}
    void add_edge(int u, int v) { adj[u].push_back(v), adj[v].push_back(u); }
    void build(int root = 0) {
        top[root] = root, dep[root] = 0, par[root] = -1;
        dfs1(root), dfs2(root);
    }
    void dfs1(int u) {
        if (auto it = find(adj[u].begin(), adj[u].end(), par[u]); it != adj[u].end()) {
            adj[u].erase(it);
        }
        for (auto &v : adj[u]) {
            par[v] = u;
            dep[v] = dep[u] + 1;
            dfs1(v);
            sz[u] += sz[v];
            if (sz[v] > sz[adj[u][0]]) { swap(v, adj[u][0]); }
        }
    }
    void dfs2(int u) {
        tin[u] = cur++;
        seq[tin[u]] = u;
        for (auto v : adj[u]) {
            top[v] = v == adj[u][0] ? top[u] : v;
            dfs2(v);
        }
        tout[u] = cur;
    }
    int lca(int u, int v) {
        while (top[u] != top[v]) {
            if (dep[top[u]] > dep[top[v]]) {
                u = par[top[u]];
            } else {
                v = par[top[v]];
            }
        }
        return dep[u] < dep[v] ? u : v;
    }
    int dist(int u, int v) { return dep[u] + dep[v] - 2 * dep[lca(u, v)]; }
    int jump(int u, int k) {
        if (dep[u] < k) { return -1; }
        int d = dep[u] - k;
        while (dep[top[u]] > d) { u = par[top[u]]; }
        return seq[tin[u] - dep[u] + d];
    }
    // u is v's ancestor
    bool is_ancestor(int u, int v) { return tin[u] <= tin[v] && tin[v] < tout[u]; }
    // root's parent is itself
    int rooted_parent(int r, int u) {
        if (r == u) { return u; }
        if (is_ancestor(r, u)) { return par[u]; }
        auto it = upper_bound(adj[u].begin(), adj[u].end(), r, [&](int x, int y) {
            return tin[x] < tin[y];
        }) - 1;
        return *it;
    }
    // rooted at u, v's subtree size
    int rooted_size(int r, int u) {
        if (r == u) { return n; }
        if (is_ancestor(u, r)) { return sz[u]; }
        return n - sz[rooted_parent(r, u)];
    }
    int rooted_lca(int r, int a, int b) { return lca(a, b) ^ lca(a, r) ^ lca(b, r); }
};

// res : parent of each vertex in dominator tree, -1 is root, -2 if not in tree
struct DominatorTree {
    int n, cur = 0;
    vector<int> dfn, rev, fa, sdom, dom, val, rp, res;
    vector<vector<int>> adj, rdom, r;
    DominatorTree(int n) : n(n), dfn(n, -1), res(n, -2), adj(n), rdom(n), r(n) {
        rev = fa = sdom = dom = val = rp = dfn;
    }
    void add_edge(int u, int v) {
        adj[u].push_back(v);
    }
    void dfs(int u) {
        dfn[u] = cur;
        rev[cur] = u;
        fa[cur] = sdom[cur] = val[cur] = cur;
        cur++;
        for (int v : adj[u]) {
            if (dfn[v] == -1) {
                dfs(v);
                rp[dfn[v]] = dfn[u];
            }
            r[dfn[v]].push_back(dfn[u]);
        }
    }
    int find(int u, int c) {
        if (fa[u] == u) {
            return c != 0 ? -1 : u;
        }
        int p = find(fa[u], 1);
        if (p == -1) {
            return c != 0 ? fa[u] : val[u];
        }
        if (sdom[val[u]] > sdom[val[fa[u]]]) {
            val[u] = val[fa[u]];
        }
        fa[u] = p;
        return c != 0 ? p : val[u];
    }
    void build(int s = 0) {
        dfs(s);
        for (int i = cur - 1; i >= 0; i--) {
            for (int u : r[i]) {
                sdom[i] = min(sdom[i], sdom[find(u, 0)]);
            }
            if (i > 0) {
                rdom[sdom[i]].push_back(i);
            }
            for (int u : rdom[i]) {
                int p = find(u, 0);
                if (sdom[p] == i) {
                    dom[u] = i;
                } else {
                    dom[u] = p;
                }
            }
            if (i > 0) {
                fa[i] = rp[i];
            }
        }
        res[s] = -1;
        for (int i = 1; i < cur; i++) {
            if (sdom[i] != dom[i]) {
                dom[i] = dom[dom[i]];
            }
        }
        for (int i = 0; i < n; i++) {
            res[rev[i]] = rev[dom[i]];
        }
    }
};

template <class Info, class Tag>
struct LazySegmentTree {
    int n;
    vector<Info> info;
    vector<Tag> tag;
    LazySegmentTree(int n) : n(n), info(4 * n), tag(4 * n) {}
template <typename T>
    LazySegmentTree(vector<T> init) : LazySegmentTree(init.size()) {
        auto go = [&](auto go, int id, int l, int r) -> void {
            if (r - l == 1) {
                info[id] = {init[l]};
                return;
            }
            int m = l + r >> 1;
            go(go, id << 1, l, m);
            go(go, id << 1 | 1, m, r);
            pull(id);
        };
        go(go, 1, 0, n);
    }
    void pull(int id) {
        info[id] = info[id << 1] + info[id << 1 | 1];
    }
    void apply(int id, const Tag &v) {
        info[id] += v;
        tag[id] += v;
    }
    void push(int id) {
        apply(id << 1, tag[id]);
        apply(id << 1 | 1, tag[id]);
        tag[id] = Tag();
    }
    void modify(int p, const Info &v) {
        auto go = [&](auto go, int id, int l, int r) -> void {
            if (r - l == 1) {
                info[id] = v;
                return;
            }
            int m = l + r >> 1;
            push(id);
            p < m ? go(go, id << 1, l, m) : go(go, id << 1 | 1, m, r);
            pull(id);
        };
        go(go, 1, 0, n);
    }
    Info rangeQuery(int ql, int qr) {
        auto go = [&](auto go, int id, int l, int r) -> Info {
            if (qr <= l || r <= ql) {
                return Info();
            }
            if (ql <= l && r <= qr) {
                return info[id];
            }
            int m = l + r >> 1;
            push(id);
            return go(go, id << 1, l, m) + go(go, id << 1 | 1, m, r);
        };
        return go(go, 1, 0, n);
    }
    void rangeApply(int ql, int qr, const Tag &v) {
        auto go = [&](auto go, int id, int l, int r) -> void {
            if (qr <= l || r <= ql) {
                return;
            }
            if (ql <= l && r <= qr) {
                apply(id, v);
                return;
            }
            int m = l + r >> 1;
            push(id);
            go(go, id << 1, l, m), go(go, id << 1 | 1, m, r);
            pull(id);
        };
        go(go, 1, 0, n);
    }
template <typename F>
    int findFirst(int ql, int qr, F f) {
        auto go = [&](auto go, int id, int l, int r) -> int {
            if (qr <= l || r <= ql || !f(info[id])) {
                return n;
            }
            if (r - l == 1) {
                return l;
            }
            push(id);
            int m = l + r >> 1;
            int res = go(go, id << 1, l, m);
            if (res == n) {
                res = go(go, id << 1 | 1, m, r);
            }
            return res;
        };
        return go(go, 1, 0, n);
    }
template <typename F>
    int findLast(int ql, int qr, F f) {
        auto go = [&](auto go, int id, int l, int r) -> int {
            if (qr <= l || r <= ql || !f(info[id])) {
                return -1;
            }
            if (r - l == 1) {
                return l;
            }
            push(id);
            int m = l + r >> 1;
            int res = go(go, id << 1 | 1, m, r);
            if (res == -1) {
                res = go(go, id << 1, l, m);
            }
            return res;
        };
        return go(go, 1, 0, n);
    }
};

constexpr i64 inf = 1e18;

struct Info {
    i64 x = inf, cmin = inf;
};

struct Tag {
    i64 x = inf, y = 0;
};

Info operator+(Info a, Info b) {
    return {min(a.x, b.x), min(a.cmin, b.cmin)};
}

Info& operator+=(Info &a, Tag b) {
    a.x += b.y;
    a.x = min(a.x, b.x + a.cmin);
    return a;
}

Tag& operator+=(Tag &a, Tag b) {
    a.y += b.y;
    a.x += b.y;
    a.x = min(a.x, b.x);
    return a;
}

int main() {
    cin.tie(nullptr)->sync_with_stdio(false);

    int t;
    cin >> t;

    auto solve = [&]() {
        int n, m, q;
        cin >> n >> m >> q;

        DominatorTree dt(n);
        for (int i = 0; i < m; i++) {
            int u, v;
            cin >> u >> v;
            u--, v--;
            dt.add_edge(v, u);
        }
        dt.build();

        HLD g(n);
        for (int i = 1; i < n; i++) {
            int j = dt.res[i];
            g.add_edge(i, j);
        }
        g.build();

        vector<int> c(n);
        for (int i = 0; i < n; i++) {
            cin >> c[i];
        }

        // vector dp(q + 1, vector<i64>(n + 1, inf));
        // dp[0][n] = 0;

        // for (int i = 0; i < q; i++) {
        //     int a, b;
        //     cin >> a >> b;
        //     a--;

        //     dp[i + 1] = dp[i];
        //     i64 x = *min_element(dp[i].begin(), dp[i].end());
        //     for (int j = 0; j <= n; j++) {
        //         dp[i + 1][j] = min(dp[i + 1][j], x + (j < n ? c[j] : inf));
        //     }
        //     for (int j = 0; j < n; j++) {
        //         if (!g.is_ancestor(j, a)) {
        //             dp[i + 1][j] += b;
        //         }
        //     }
        //     dp[i + 1][n] += b;

        //     cout << *min_element(dp[i + 1].begin(), dp[i + 1].end()) << " \n"[i + 1 == q];
        // }

        LazySegmentTree<Info, Tag> st(n + 1);
        for (int i = 0; i < n; i++) {
            st.modify(g.tin[i], {inf, c[i]});
        }
        st.modify(n, {0, inf});

        for (int i = 0; i < q; i++) {
            int a, b;
            cin >> a >> b;
            a--;

            auto mn = st.rangeQuery(0, n + 1).x;
            st.rangeApply(0, n + 1, Tag{mn, 0});

            while (a >= 0) {
                int p = g.top[a];
                st.rangeApply(g.tin[p], g.tin[a] + 1, Tag{inf, -b});
                a = g.par[p];   
            }
            st.rangeApply(0, n + 1, Tag{inf, b});

            cout << st.rangeQuery(0, n + 1).x << " \n"[i + 1 == q];
        }
    };

    while (t--) {
        solve();
    }
    
    return 0;
}

这程序好像有点Bug,我给组数据试试?

Details

Tip: Click on the bar to expand more detailed information

Test #1:

score: 100
Accepted
time: 0ms
memory: 3664kb

input:

3
7 6 4
2 1
3 1
4 2
5 2
6 3
7 3
4 3 5 2 2 1 1
4 2
5 2
6 2
7 2
5 6 4
1 3
3 2
2 1
4 2
5 4
2 5
10000 10000 2 100 5
5 1000
4 1000
3 1000
4 1000
4 4 1
2 1
3 1
4 2
4 3
100 1 1 100
4 10

output:

2 3 4 4
5 100 102 202
10

result:

ok 9 numbers

Test #2:

score: 0
Accepted
time: 69ms
memory: 3652kb

input:

10000
10 15 10
5 4
4 8
8 1
9 1
3 1
7 10
2 4
2 8
10 9
8 1
3 2
8 9
6 3
9 6
9 7
109573034 995191779 629441974 818963404 427826881 504492389 571193150 526828914 397022133 261597684
10 372333138
2 502585557
6 146333017
6 522319681
10 272972971
9 958277860
6 81039902
10 30321248
6 459502525
6 753468360
10...

output:

109573034 109573034 109573034 109573034 109573034 109573034 109573034 109573034 109573034 109573034
302793882 302793882 302793882 302793882 392542446 392542446 392542446 392542446 392542446 392542446
14673922 527692254 527692254 527692254 527692254 527692254 527692254 527692254 527692254 527692254
3...

result:

ok 100000 numbers

Test #3:

score: 0
Accepted
time: 75ms
memory: 3656kb

input:

10000
10 20 10
7 4
6 1
5 1
4 6
10 1
8 7
10 6
10 7
6 5
5 7
7 3
3 10
9 5
8 1
2 3
2 7
5 1
10 5
6 9
4 10
714813381 27732963 16286651 18609639 333483693 125576688 108264816 25878619 235574069 240050850
7 567613610
3 232248158
3 248483123
2 509643192
2 429418762
8 740634945
5 452715309
3 823602753
5 40063...

output:

108264816 124551467 124551467 152284430 152284430 178163049 511646742 527933393 567997344 676262160
26807100 86723092 172308368 220150563 220150563 220150563 220150563 220150563 220150563 220150563
219954028 315305437 315305437 535259465 630610874 660050539 660050539 755829134 757689273 787417404
92...

result:

ok 100000 numbers

Test #4:

score: 0
Accepted
time: 94ms
memory: 3712kb

input:

1000
100 200 100
100 85
25 41
51 60
80 53
35 3
85 3
60 9
80 77
45 84
74 87
9 4
49 94
99 86
95 35
80 42
62 43
38 56
10 29
69 23
30 67
72 13
43 11
69 5
9 40
65 1
19 17
13 61
58 11
92 87
33 16
13 86
24 9
51 18
46 74
28 45
91 3
6 39
67 13
63 72
58 43
50 49
34 16
67 16
46 30
39 33
4 30
13 41
61 45
54 49
...

output:

64935453 70965771 71328539 84563196 101126032 182452343 183929386 189086513 189449281 198674817 212642620 458896124 486583003 502334898 504091090 504300836 533836295 535592487 552248176 557405303 598430396 604669787 615853847 621911960 628151351 628514119 637212958 640828512 670009009 670009009 6700...

result:

ok 100000 numbers

Test #5:

score: 0
Accepted
time: 99ms
memory: 4300kb

input:

100
1000 2000 1000
580 434
648 991
698 983
127 160
396 673
132 546
769 964
619 11
930 346
927 295
346 781
790 225
346 153
771 540
417 831
278 938
831 162
334 468
181 1000
430 926
825 836
111 425
454 139
664 213
541 742
82 324
910 567
937 941
933 54
478 602
465 223
90 800
678 250
446 455
15 87
682 22...

output:

147981 6057285 6763519 8324914 12134004 60851566 61199876 61783409 62637532 62718179 63255476 64828340 73262762 77883615 78817240 79419339 79446296 79502338 79951733 81341716 81847946 87020064 88412512 89728687 90965454 91926421 93371746 94054227 115092673 122095986 125048869 125323752 125381706 125...

result:

ok 100000 numbers

Test #6:

score: 0
Accepted
time: 118ms
memory: 7356kb

input:

10
10000 20000 10000
6196 1463
7511 8792
2131 9398
896 3914
2977 9715
6897 4298
2547 1947
6436 5395
7836 2909
2278 5947
3783 1405
3177 9748
6280 348
3913 6678
5250 5153
5850 3470
1235 1974
6303 8570
6185 2060
6435 3492
2333 2856
9193 8923
8003 4365
5334 9689
632 3118
591 4799
1339 3380
6453 5082
546...

output:

32265 618864 632948 737344 761241 789193 894444 1076258 1164521 1999194 2175573 3059944 3064809 3127704 3154368 3159912 3180311 3261891 3409778 3424562 3489319 3567017 3724551 3781325 3795404 4402433 4405941 4694408 4786783 4854528 4862930 4868817 8159854 8201632 8280925 8903595 8988190 9055965 9132...

result:

ok 100000 numbers

Test #7:

score: 0
Accepted
time: 160ms
memory: 44116kb

input:

1
100000 200000 100000
40517 64052
42036 17071
37780 52362
86808 24357
89653 74468
42769 89912
71292 44370
31818 78852
84553 7078
3258 9500
11388 52056
42673 78015
49296 65204
28466 57602
7547 75680
14931 13489
16195 25975
62425 71782
80892 83445
82033 10050
66265 86587
38331 88357
31078 89962
71594...

output:

26734 28727 30146 32253 40375 60341 62478 89325 97996 107091 111825 114407 127041 149531 167269 170485 192794 194176 287594 295279 1958976 1963133 1970337 1974055 2001413 2040525 2041839 2050592 2056769 2073363 2082803 2097474 2109669 2115430 2121140 2128333 2130757 2134698 2139041 2153097 2156553 2...

result:

ok 100000 numbers

Test #8:

score: 0
Accepted
time: 166ms
memory: 44156kb

input:

1
100000 200000 100000
25508 70004
75638 20043
9718 63526
72022 95936
67619 1003
72446 94411
81273 13282
46237 792
20571 5800
39511 20749
49117 47811
50770 63360
8275 45957
39364 93191
58638 12759
61325 83734
88743 54563
38117 13205
73526 97285
16986 55135
53169 50475
54520 93704
52603 49792
70981 6...

output:

6712 8811 18673 146439 148477 159530 179664 183150 200509 207081 210705 217659 392494 398902 523814 533774 538904 643470 652198 657065 684906 711954 720312 730309 730445 734121 750887 758464 762948 763257 768740 786682 816667 817596 830156 830782 832982 835062 839670 864485 929425 963164 990181 9922...

result:

ok 100000 numbers

Test #9:

score: 0
Accepted
time: 170ms
memory: 44120kb

input:

1
100000 200000 100000
75856 57750
8144 79846
28171 90761
13047 34611
78592 97801
5906 38255
91274 89885
89207 22354
22251 53722
6474 56452
84774 35973
15069 63667
57488 44746
60179 32774
58536 66648
99558 82642
87314 43045
68171 37631
2068 1390
80865 22136
67893 86088
75465 89141
61251 85318
31456 ...

output:

2244 16182 17234 28317 31234 59554 60500 70910 76218 142863 968630 984604 987249 991130 1001000 1003272 1021359 1068894 1080866 1082961 1085257 1092172 1097682 1098282 2517218 2519542 2524451 2526013 2532190 2536494 2539806 2570432 2570700 2583774 2584880 2608937 2780046 2786320 2786647 2795545 2796...

result:

ok 100000 numbers

Test #10:

score: 0
Accepted
time: 170ms
memory: 44136kb

input:

1
100000 200000 100000
45607 5725
95112 13728
81881 72369
78757 85639
10861 30074
27959 66414
15097 75809
67672 37380
3790 11649
74901 58793
16241 80379
13306 90613
25775 40577
30763 57210
37307 90450
8851 4115
73856 82785
55235 48774
54117 6814
49289 47070
49068 56982
33549 77041
15736 3653
64862 7...

output:

619993 628617 635757 712308 720211 723292 727320 731194 1025759 1039054 1183571 1193900 1195946 1203339 1205149 1206292 1210172 1214743 1216525 1220888 1312607 1313732 1323200 1329014 1332177 1333282 1334281 1340105 1340306 1375844 1379377 1381848 1385940 1386565 1387775 1390955 1402512 1405435 1422...

result:

ok 100000 numbers

Test #11:

score: 0
Accepted
time: 155ms
memory: 44264kb

input:

1
100000 200000 100000
34214 81103
61485 84618
7161 64013
99501 74874
56237 31133
57821 96960
56325 61862
93452 5171
18438 80922
76442 93785
80586 59332
42275 62691
89623 63452
29309 99496
30469 60837
13118 40588
78498 43331
15988 14693
2388 54972
81369 78712
69487 47884
82691 40779
82137 98114
1546...

output:

19377 20242 28749 34862 43579 62503 106728 205407 214228 271605 293174 297448 299913 307477 311790 354770 360534 368977 376060 381262 384122 397659 405819 408293 419085 420800 430308 439899 440516 444206 448763 454873 472848 473155 541829 548985 549713 572046 619426 622578 627023 639054 648453 65989...

result:

ok 100000 numbers

Test #12:

score: 0
Accepted
time: 103ms
memory: 7472kb

input:

10
10000 9999 9999
7761 8505
3944 3673
7338 9501
9031 4052
1975 8230
2065 7295
6727 9867
6961 4940
6860 5756
5791 5557
2589 933
8349 5891
6455 5423
4556 5912
8005 1626
8236 7115
780 422
4403 9199
4631 1429
5098 799
839 9641
3800 5646
4832 7155
1691 8553
9188 7191
3023 9469
318 4448
465 4853
4714 93
...

output:

28167 85044 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 17706309 ...

result:

ok 99990 numbers

Test #13:

score: 0
Accepted
time: 138ms
memory: 45464kb

input:

1
100000 99999 99999
6296 13416
40856 99982
77418 735
83419 54826
46876 92865
24478 83125
64008 57977
20939 91086
7709 90399
15198 4452
42269 34425
83724 20659
6319 41157
9422 54263
71815 33006
40460 64075
39832 83092
23050 22944
71586 72307
80950 19277
99720 483
4124 97865
22245 27145
93957 79618
5...

output:

11183 9395822 9395822 9400367 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 12279642 ...

result:

ok 99999 numbers

Test #14:

score: 0
Accepted
time: 131ms
memory: 46608kb

input:

1
100000 99999 99999
41599 51389
80642 57058
4610 59691
53781 53430
21549 85283
86646 1292
15260 27952
56098 69644
36659 93526
1866 95885
45956 97523
92945 45561
1238 55479
81755 60616
83871 90510
31736 15501
23962 96177
3710 94534
1920 99950
16207 48270
61169 75988
13870 76680
8859 4115
93802 53555...

output:

10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10737729 10744574 10752080 10753043 10758950 10786032 10786543 10792764 10815164 10822948 10945183 10945183 10945183 10945183 10945183 10945183 10945183 10945183 10945183 10945183 109...

result:

ok 99999 numbers

Test #15:

score: 0
Accepted
time: 142ms
memory: 48464kb

input:

1
100000 99999 99999
69552 81325
29339 46636
60241 52439
21904 43472
32396 88893
68363 81529
26228 54771
43086 31837
63398 64092
9186 86980
28551 77600
81698 30519
55349 54776
40813 64966
78196 75720
27804 46023
13360 93887
34524 65224
89025 53277
10351 8099
12964 79463
14807 31100
59111 7054
21174 ...

output:

6411390 6411390 6411390 6416853 6498795 8046171 8055187 8064669 10751767 10751767 10751767 10751767 10751767 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10974147 10...

result:

ok 99999 numbers

Test #16:

score: 0
Accepted
time: 117ms
memory: 7300kb

input:

10
10000 9999 9999
6304 177
9290 5667
4456 5225
7073 951
9644 5452
2213 1219
8520 2663
3656 6082
2482 2177
1992 2366
1680 1439
3037 2347
1670 9330
8052 4789
2591 7293
9531 7339
6714 3193
7142 540
5498 5385
4504 8442
3614 8421
3053 3082
3887 9934
3487 8288
127 4796
294 1429
2123 7993
6197 3719
6084 8...

output:

176780 4042271 4042271 4196329 4233477 126063463 126063463 126063463 126063463 126063463 126404969 126623458 128594183 128679154 128917104 128970240 128974813 128977719 129023819 129145262 130810693 130877263 131092767 131384195 135943840 135943840 135943840 135973734 140533379 140533379 140551935 1...

result:

ok 99990 numbers

Test #17:

score: 0
Accepted
time: 153ms
memory: 43612kb

input:

1
100000 99999 99999
84861 72308
98771 35981
62693 28557
87570 29894
84930 44017
33747 74112
54091 1538
6583 49820
60656 88373
41231 57844
49295 31586
3364 12646
22396 81200
14514 54457
22126 75780
17397 60158
67877 70986
42425 15990
59555 46169
75025 69735
11255 52109
32302 5559
68353 46431
10687 9...

output:

384 10235 745394 750207 3640677 5762057 5765625 8809578 12140184 12492215 16771813 18698262 18703700 18712737 18716026 18750949 23490596 23490596 23490596 23490596 23941266 23945847 26346019 28305810 28337150 28345875 31500543 31502439 31509411 31520335 33059074 33063007 33096256 35326853 35326853 3...

result:

ok 99999 numbers

Test #18:

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

input:

1
100000 99999 99999
74573 61528
89747 63719
74205 87153
49920 69002
63075 64452
66675 82478
52520 16834
22290 48022
36649 3016
16088 23446
18091 65389
16935 98307
44455 41239
82597 37216
46414 93350
95081 3269
82386 53717
2044 94956
9984 43369
71251 28532
46020 47501
46304 84601
34762 65963
80549 6...

output:

21773 22384 5239186 5239186 5239186 5245757 6445150 6445150 6446550 6474144 8875725 8897774 8910616 8912218 11564511 11576794 15100107 19937784 19939952 20932454 20937055 20944953 21790728 21792036 21799857 21809510 21826494 21833371 21838361 23718560 23745307 23765753 24414660 24422522 29639324 296...

result:

ok 99999 numbers

Test #19:

score: 0
Accepted
time: 130ms
memory: 45508kb

input:

1
100000 99999 99999
62434 43660
46776 39730
80278 28275
86847 48823
51085 47167
72544 5694
68065 36311
90256 44091
13588 84576
40712 80837
6488 80765
54154 37906
1511 63070
9051 50992
77789 42160
80243 79618
8598 81427
43300 32425
12470 66259
99776 95431
93220 53979
35938 24946
74557 77705
51473 71...

output:

4707 2181115 4247113 4252707 4262127 4264258 8739918 11725567 11726085 13396290 13396290 13396290 17442689 17871950 17977108 21244267 23644026 28119686 28128221 30304629 32603881 32941406 34124345 34125296 34134391 34135495 38611155 43334377 47868717 47868717 47880738 50057146 50061744 52150816 5282...

result:

ok 99999 numbers

Test #20:

score: 0
Accepted
time: 105ms
memory: 6988kb

input:

10
10000 9999 9999
9638 1
2091 8776
8777 1
437 1
9756 4312
6619 1
6355 5408
6246 9915
3144 987
3172 1
1136 1
7380 3820
71 2040
6986 9465
8695 9801
788 8172
6969 1
2954 2303
3638 1
5168 4738
6 1
7418 9411
7932 7678
4682 1
9773 7637
211 1
3548 1
5392 1
5724 1
9574 131
3924 1
1898 6197
3083 9719
756 1
...

output:

51725 346005 381966 450188 535556 880262 961754 1032929 1034412 1084714 1184781 1267663 1316312 1551235 1561695 1575130 1611862 1639566 1750340 1756883 1765048 1789117 1844363 1930059 1933269 1946003 1986314 2063675 2131309 2148785 2350835 2425745 2468575 2492428 2495955 2635809 2783617 2905463 3003...

result:

ok 99990 numbers

Test #21:

score: 0
Accepted
time: 134ms
memory: 40168kb

input:

1
100000 99999 99999
493 1
31592 1
10575 45254
32599 23007
18687 1
82032 15540
58095 1
30841 33978
29578 1
13023 57263
9879 1
76097 93562
55029 89168
39021 1
99275 6312
76653 1
10007 1
68797 60922
87732 56943
60049 1
24179 35417
69765 22800
58393 1
85031 54077
90554 39617
11652 45320
43543 1
81825 1...

output:

15371 22708 31786 44554 49746 53411 65977 66461 67870 70567 71020 77734 88627 90171 98302 102344 106627 144852 155974 158274 161076 165801 174918 179482 183481 184586 190037 193692 203606 206593 210330 214839 232238 237033 239757 247470 252914 274656 296809 299808 312957 316888 320522 331267 345032 ...

result:

ok 99999 numbers

Test #22:

score: 0
Accepted
time: 126ms
memory: 40192kb

input:

1
100000 99999 99999
22641 67268
66453 1
34467 19355
58748 90440
60136 68473
5041 1
50518 1
17241 1
5886 1
43792 1
17387 1
70273 1
30448 1
59338 1
68702 1
24498 18340
51068 42791
56644 1
50267 1
41720 31098
10020 17826
50681 1
4900 80354
74669 1
89968 22110
19000 97750
47640 1
51524 15975
52257 9843...

output:

3940 16407 19870 25723 32841 48247 53558 56418 61829 93933 100547 109877 112617 112909 113783 128645 129868 134303 141310 142675 149200 151029 206694 218316 224257 230760 235777 241302 264066 423469 428274 431797 446818 465045 472532 474836 492524 494370 502798 503488 506996 512478 515583 533088 540...

result:

ok 99999 numbers

Test #23:

score: 0
Accepted
time: 135ms
memory: 40268kb

input:

1
100000 99999 99999
56868 1
88114 1
73681 10511
61435 40178
72122 1
9770 78914
54681 1
35152 1
31039 5715
36959 1
38907 6387
71158 1
94938 1
91622 1
35809 90155
85477 1
39692 56449
26271 49071
33916 86549
60427 1
71766 3220
96174 88225
34761 12291
72521 1
36122 69393
64869 77230
29321 1
12070 1
153...

output:

6376 13198 13843 252581 253421 256869 260753 267016 273449 279732 285336 287460 287774 293574 302254 307670 325324 325676 350518 352148 362719 365492 369134 374411 376031 380773 419964 423417 424816 438755 447752 449890 465935 495310 497498 498233 516548 527094 535967 540163 543715 544729 545511 555...

result:

ok 99999 numbers

Test #24:

score: 0
Accepted
time: 173ms
memory: 7228kb

input:

10
10000 9999 9999
4270 1100
5513 5252
5517 3334
643 6481
7063 3943
8548 1223
1410 3925
7136 520
3535 703
4251 3280
4462 6929
5193 9830
9596 8087
2183 1736
2733 2720
3094 8982
6584 3877
2160 4529
807 4161
5917 9356
5841 231
6331 7421
6236 996
3497 5471
4871 6851
5215 7749
9839 3294
6973 8670
6053 39...

output:

42908 51736 281589 288668 337995 343085 349996 368386 407350 510765 663247 696637 726430 834977 1029898 1064952 1113449 1512147 1583856 1981303 10248305 10248305 10384136 10717192 10730609 10746853 10750278 10989614 11053880 11150430 12838651 12863316 12871442 12901991 13018872 13694193 13719597 137...

result:

ok 99990 numbers

Test #25:

score: 0
Accepted
time: 289ms
memory: 40548kb

input:

1
100000 99999 99999
84098 77135
11865 76825
3397 66194
23361 35772
24618 69950
56566 38393
37841 72489
51955 52967
1889 53852
33207 22536
69718 17248
78507 93973
73124 55523
41421 27810
74933 15051
46401 14510
79023 51137
62616 95992
10083 51634
50828 53370
66230 76404
77516 88458
34431 34381
45102...

output:

6757 7940 13537 35131 37259 39248 40135 109405 151662 639895 659579 661859 664020 665141 688873 718803 730250 775504 779279 784826 836216 844197 849281 855140 862718 886309 932949 960470 992899 996247 1017478 1041142 1043689 1048817 1056989 1091236 1091471 1096129 1097858 1106333 1107323 1118280 114...

result:

ok 99999 numbers

Test #26:

score: 0
Accepted
time: 290ms
memory: 40768kb

input:

1
100000 99999 99999
435 34640
45328 3373
92021 75220
66927 71579
64414 11043
56902 69386
7246 69788
67536 81405
2532 19200
89152 4555
42910 12253
60444 66389
91369 48080
46717 72737
42984 18904
85853 71657
83193 6055
37274 25175
6844 13450
23195 44256
31295 22347
58211 83113
14595 45139
46205 10221...

output:

10443 113422 136658 157490 169924 172403 181714 188709 305645 308009 311392 380725 388746 397666 419945 432943 455374 456261 460017 471740 474187 483830 492619 499663 511694 542263 543336 588117 713069 717318 722012 736570 742382 787024 788965 809074 817893 820134 822111 825525 831071 893250 901060 ...

result:

ok 99999 numbers

Test #27:

score: 0
Accepted
time: 274ms
memory: 40732kb

input:

1
100000 99999 99999
98867 2559
52899 68196
66542 6562
85784 47893
81433 22034
24663 29406
80017 5969
53683 71589
84681 68455
14459 31688
8706 27736
97372 67696
33772 67537
5012 66192
37902 4285
39971 72225
88286 10112
28982 90116
93971 67030
47327 90004
65969 86210
65581 51682
21668 13503
36649 711...

output:

7801 11708 17288 22185 22655 24078 25163 36128 150331 156860 161907 165659 229299 243831 252104 276593 285329 294310 296443 299345 301518 305861 306911 330869 348979 465769 468297 487466 670884 673974 727119 728287 732245 733379 753001 762557 763013 771652 772002 773611 781283 788537 798708 810630 8...

result:

ok 99999 numbers

Extra Test:

score: 0
Extra Test Passed