QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#308850#8136. Rebellious Edgeucup-team159#AC ✓32ms25696kbC++2314.6kb2024-01-20 13:23:272024-01-20 13:23:28

Judging History

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

  • [2024-01-20 13:23:28]
  • 评测
  • 测评结果:AC
  • 用时:32ms
  • 内存:25696kb
  • [2024-01-20 13:23:27]
  • 提交

answer

// https://judge.yosupo.jp/submission/86049

#include <bits/stdc++.h>
#ifdef LOCAL
#  include <dbg.h>
#else
#  define dbg(...) do {} while (0)
#endif

#define cp_lib_4th(_1, _2, _3, x, ...)  x
#define cp_lib_rep(i, l, r)             for (int i = (l); (i) < (r); ++(i))
#define cp_lib_rep0(i, r)               cp_lib_rep(i, 0, r)
#define rep(...)                        cp_lib_4th(__VA_ARGS__, cp_lib_rep, cp_lib_rep0, _)(__VA_ARGS__)
#define cp_lib_repr(i, r, l, ...)       for (int i = (r); (i) >= (l); --(i))
#define repr(...)                       cp_lib_repr(__VA_ARGS__, 0)
#define all(a)                          ::begin(a),::end(a)
#define trav(a, b)                      for (auto&& a : (b))

using namespace std;
using ll = long long;
using ld = long double;
[[maybe_unused]] static constexpr int INF = int(1e9 + 5);
[[maybe_unused]] static constexpr ll INFL = ll(INF) * INF;
template <class C> int sz(const C& c) { return int(::size(c)); }


#ifdef CP_LIB_DEBUG
#define cp_lib_assert(expr) \
    do { if (!(expr)) { \
        ::cerr << "assertion failed: " << #expr << " (" << __FILE__ << ':' << __LINE__ << ")\n"; \
        ::abort(); \
    } } while (0)
#else
#define cp_lib_assert(expr)
#endif


#if __cplusplus < 202002L
struct identity { template <class T> constexpr T&& operator()(T&& t) const noexcept { return forward<T>(t); }; };
#endif
#if __cpp_lib_remove_cvref < 201711L
template <class T> using remove_cvref_t = remove_cv_t<remove_reference_t<T>>;
#endif

namespace cp_lib_type_meta {
    template <class T, class = void> constexpr bool is_tuple_like = false;
    template <class T> constexpr bool is_tuple_like<T, void_t<tuple_element_t<0, T>>> = true;
}


namespace cp_lib_modint { struct ModIntTag {}; }
#include <unistd.h>

namespace cp_lib_io {
    constexpr int BUF_SIZE = 1 << 20;
    constexpr array<array<char, 4>, 10'000> DIGITS = []{
        array<array<char, 4>, 10'000> digits{};
        for (int i = 3, d = 1; i >= 0; --i, d *= 10)
            rep(j, 10'000)
                digits[j][i] = char('0' + j / d % 10);
        return digits;
    }();
    array<char, BUF_SIZE> ibuf, obuf;
    char *iptr = data(ibuf), *iend = iptr, *optr = data(obuf);

    template <class T> constexpr bool is_std_array = false;
    template <class T, size_t I> constexpr bool is_std_array<array<T, I>> = true;

    void flush() {
        for (auto* p = begin(obuf); p != optr; p += write(STDOUT_FILENO, p, optr - p));
        optr = begin(obuf);
    }
    int _flush_atexit = []{ atexit(flush); return 0; }();

    void refill() {
        memmove(begin(ibuf), iptr, iend - iptr);
        iend -= iptr - begin(ibuf);
        iptr = begin(ibuf);
        iend += read(STDIN_FILENO, iend, end(ibuf) - 1 - iend);
        *iend = '\0';
    }

    template <class T, class T2 = remove_cvref_t<T>>
    void print(T&& val) {
        if (end(obuf) - optr < 64)
            flush();

        if constexpr (is_same_v<T2, char>)
            *optr++ = val;
        else if constexpr (is_same_v<T2, bool> || is_same_v<T2, vector<bool>::reference>)
            return print(int(val));
        else if constexpr (is_integral_v<T2> && is_signed_v<T2>) {
            if (val < 0)
                *optr++ = '-';
            using U = make_unsigned_t<T2>;
            return print(U(val < 0 ? -U(val) : U(val)));
        } else if constexpr (is_integral_v<T2> && is_unsigned_v<T2>) {
            T2 val2 = val;
            array<char, 64> tmp;
            char* tptr = end(tmp);
            while (val2 >= 10'000)
                tptr -= 4, memcpy(tptr, &DIGITS[val2 % 10'000][0], 4), val2 /= T2(10'000);
            int d = (val2 >= 100 ? (val2 >= 1000 ? 4 : 3) : (val2 >= 10 ? 2 : 1));
            memcpy(optr, &DIGITS[val2][4 - d], d);
            memcpy(optr + d, tptr, end(tmp) - tptr);
            optr += d + int(end(tmp) - tptr);
        } else if constexpr (is_floating_point_v<T2>)
            optr += sprintf(optr, "%.30Lf", (long double)val);
        else if constexpr (is_convertible_v<T, string_view>) {
            string_view sv(val);
            if (sz(sv) + 1 <= end(obuf) - optr)
                memcpy(optr, data(sv), sz(sv)), optr += sz(sv);
            else {
                flush();
                for (auto *p = data(sv), *pe = p + sz(sv); p != pe; p += write(STDOUT_FILENO, p, pe - p));
            }
        } else if constexpr (is_base_of_v<cp_lib_modint::ModIntTag, T2>)
            return print(decltype(T2::mod())(val));
        else if constexpr (cp_lib_type_meta::is_tuple_like<T2> && !is_std_array<T2>)
            return apply([](auto&&... items) { (print(items), ...); }, forward<T>(val));
        else {
            trav(item, val)
                print(item);
            return;
        }
        *optr++ = ' ';
    }

    template <class T>
    void read(T& val) {
        auto skip_ws = [] {
            do {
                for (; iptr != iend && *iptr <= ' '; ++iptr);
                if (iend - iptr < 64)
                    refill();
            } while (*iptr <= ' ');
        };
        auto read_other = [&](auto other) {
            read(other);
            return other;
        };

        if constexpr (is_same_v<T, char>)
            skip_ws(), val = *iptr++;
        else if constexpr (is_same_v<T, bool> || is_same_v<T, vector<bool>::reference>) {
            val = bool(read_other(uint8_t()));
        } else if constexpr (is_base_of_v<cp_lib_modint::ModIntTag, T>) {
            val = T(read_other(ll()));
        } else if constexpr (is_integral_v<T>) {
            skip_ws();
            if (is_signed_v<T> && *iptr == '-')
                ++iptr, val = T(-read_other(make_unsigned_t<T>()));
            else
                for (val = 0; iptr != iend && *iptr > ' '; val = T(10 * val + (*iptr++ & 15)));
        } else if constexpr (is_floating_point_v<T>)
            skip_ws(), val = T(strtold(iptr, &iptr));
        else if constexpr (is_same_v<T, string>) {
            skip_ws();
            val.clear();
            do {
                auto* after = find_if(iptr, iend, [](char c) { return c <= ' '; });
                val.append(iptr, after);
                if ((iptr = after) != iend)
                    break;
                refill();
            } while (iptr != iend);
        } else if constexpr (cp_lib_type_meta::is_tuple_like<T> && !is_std_array<T>)
            apply([](auto&... items) { (read(items), ...); }, val);
        else
            trav(item, val)
                read(item);
    }
}

using cp_lib_io::flush;

template <class... Args>
void print(Args&&... args) { (cp_lib_io::print(forward<Args>(args)), ...); }

template <class... Args>
void println(Args&&... args) {
    if (sizeof...(Args))
        (cp_lib_io::print(forward<Args>(args)), ...), *(cp_lib_io::optr - 1) = '\n';
    else
        print('\n'), --cp_lib_io::optr;
}

template <class... Args>
void read(Args&... args) { (cp_lib_io::read(args), ...); }



struct Dsu {
    vector<int> p;

    explicit Dsu(int n) : p(n, -1) {}

    int find(int i) { return p[i] < 0 ? i : p[i] = find(p[i]); }
    bool same(int i, int j) { return find(i) == find(j); }
    int size(int i) { return -p[find(i)]; }
    bool join(int i, int j) {
        i = find(i), j = find(j);
        if (i == j) return false;
        if (p[i] > p[j]) swap(i, j);
        p[i] += p[j], p[j] = i;
        return true;
    }
};


struct RollbackDsu {
    vector<int> p;
    vector<pair<int, int>> joins;

    explicit RollbackDsu(int n) : p(n, -1) {}

    int find(int i) const { return p[i] < 0 ? i : find(p[i]); }
    bool same(int i, int j) const { return find(i) == find(j); }
    int size(int i) const { return -p[find(i)]; }
    int time() const { return sz(joins); }

    bool join(int i, int j) {
        i = find(i), j = find(j);
        if (i == j) return false;
        if (p[i] > p[j]) swap(i, j);
        joins.emplace_back(j, p[j]);
        p[i] += p[j], p[j] = i;
        return true;
    }

    void rollback(int t) {
        while (sz(joins) > t) {
            auto [i, pi] = joins.back(); joins.pop_back();
            cp_lib_assert(p[p[i]] < 0);
            p[p[i]] -= pi;
            p[i] = pi;
        }
    }
};

template <class W>
struct MinCostArborescenceGraph {
 private:
    struct SkewHeapNode { int l, r, from, to; W weight, lz; };
    vector<SkewHeapNode> nodes;
    vector<int> heap;

    void apply(int i, W upd) { nodes[i].weight -= upd; nodes[i].lz += upd; }
    void push(int i) {
        if (nodes[i].l != -1) apply(nodes[i].l, nodes[i].lz);
        if (nodes[i].r != -1) apply(nodes[i].r, nodes[i].lz);
        nodes[i].lz = W(0);
    }
    int merge(int u, int v) {
        if (u == -1 || v == -1) return (u == -1 ? v : u);
        if (nodes[v].weight < nodes[u].weight) swap(u, v);
        push(u);
        nodes[u].r = merge(nodes[u].r, v);
        swap(nodes[u].l, nodes[u].r);
        return u;
    }
    void pop(int v) {
        push(heap[v]);
        heap[v] = merge(nodes[heap[v]].l, nodes[heap[v]].r);
    }

 public:
    explicit MinCostArborescenceGraph(int n, int m = 0) : heap(n, -1) { nodes.reserve(m); }

    void add_edge(int from, int to, W weight) {
        cp_lib_assert(0 <= from && from < sz(heap) && 0 <= to && to < sz(heap));
        nodes.push_back(SkewHeapNode{-1, -1, from, to, weight, W(0)});
        heap[to] = merge(heap[to], sz(nodes) - 1);
    }

    template <class WSum = W>
    pair<WSum, vector<int>> solve(int root) {
        cp_lib_assert(0 <= root && root < sz(heap));
        auto ans = WSum(0);
        vector edge(sz(heap), -1);
        vector<pair<int, int>> cycles;
        Dsu dsu_cyc(sz(heap));
        RollbackDsu dsu_contract(sz(heap));
        rep(i, sz(heap)) {
            if (i == root) continue;
            int v = i;
            while (true) {
                if (heap[v] == -1) return {W(0), {}};
                edge[v] = heap[v];
                ans += nodes[edge[v]].weight;
                apply(edge[v], nodes[edge[v]].weight);
                if (dsu_cyc.join(v, dsu_contract.find(nodes[edge[v]].from)))
                    break;

                int vnext = dsu_contract.find(nodes[edge[v]].from), t = dsu_contract.time();
                while (dsu_contract.join(v, vnext)) {
                    heap[dsu_contract.find(v)] = merge(heap[v], heap[vnext]);
                    v = dsu_contract.find(v);
                    vnext = dsu_contract.find(nodes[edge[vnext]].from);
                }
                cycles.emplace_back(edge[v], t);

                while (heap[v] != -1 && dsu_contract.same(nodes[heap[v]].from, v))
                    pop(v);
            }
        }

        for (auto it = rbegin(cycles); it != rend(cycles); ++it) {
            int vrepr = dsu_contract.find(nodes[it->first].to);
            dsu_contract.rollback(it->second);
            int vinc = dsu_contract.find(nodes[edge[vrepr]].to);
            edge[vinc] = exchange(edge[vrepr], it->first);
        }

        rep(i, sz(heap))
            edge[i] = (i == root ? -1 : nodes[edge[i]].from);
        return {ans, edge};
    }
};

struct SkewHeapNode {
    int l, r, from, to, weight, lz;
};

void skew_heap_apply(vector<SkewHeapNode>& heap, int v, int upd) {
    heap[v].weight -= upd;
    heap[v].lz += upd;
}

void skew_heap_push(vector<SkewHeapNode>& heap, int v) {
    for (int u : {heap[v].l, heap[v].r})
        if (u != -1)
            skew_heap_apply(heap, u, heap[v].lz);
    heap[v].lz = 0;
}

int skew_heap_merge(vector<SkewHeapNode>& heap, int u, int v) {
    if (u == -1 || v == -1)
        return (u == -1 ? v : u);
    if (heap[v].weight < heap[u].weight)
        swap(u, v);
    skew_heap_push(heap, u);
    heap[u].r = skew_heap_merge(heap, heap[u].r, v);
    swap(heap[u].l, heap[u].r);
    return u;
}

void skew_heap_pop(vector<SkewHeapNode>& heap, vector<int>& root, int v) {
    skew_heap_push(heap, root[v]);
    root[v] = skew_heap_merge(heap, heap[root[v]].l, heap[root[v]].r);
}

pair<ll, vector<int>> run_solve(int n, int vr, vector<SkewHeapNode> heap, vector<int> root) {
    ll ans = 0;
    vector edge(n, -1);
    vector<pair<int, int>> cycles;
    Dsu dsu_cyc(n);
    RollbackDsu dsu_contract(n);
    rep(i, n) {
        if (i == vr)
            continue;
        int v = i;
        while (true) {
            if (root[v] == -1)
                return {0ll, {}};
            edge[v] = root[v];
            ans += heap[edge[v]].weight;
            skew_heap_apply(heap, edge[v], heap[edge[v]].weight);
            if (dsu_cyc.join(v, dsu_contract.find(heap[edge[v]].from)))
                break;

            int vnext = dsu_contract.find(heap[edge[v]].from), t = dsu_contract.time();
            while (dsu_contract.join(v, vnext)) {
                root[dsu_contract.find(v)] = skew_heap_merge(heap, root[v], root[vnext]);
                v = dsu_contract.find(v);
                vnext = dsu_contract.find(heap[edge[vnext]].from);
            }
            cycles.emplace_back(edge[v], t);

            while (root[v] != -1 && dsu_contract.same(heap[root[v]].from, v))
                skew_heap_pop(heap, root, v);
        }
    }

    for (auto it = rbegin(cycles); it != rend(cycles); ++it) {
        int vrepr = dsu_contract.find(heap[it->first].to);
        dsu_contract.rollback(it->second);
        int vinc = dsu_contract.find(heap[edge[vrepr]].to);
        edge[vinc] = exchange(edge[vrepr], it->first);
    }

    rep(i, n)
        edge[i] = (i == vr ? -1 : heap[edge[i]].from);
    return {ans, edge};
}

auto solve_new(int n, int vr, const vector<array<int, 3>>& edges) {
    int m = sz(edges);
    vector deg(n, 0);
    for (auto [_, v, _2] : edges)
        deg[v]++;
    partial_sum(all(deg), begin(deg));

    vector<SkewHeapNode> heap(m);
    for (auto [u, v, w] : edges)
        heap[--deg[v]] = {-1, -1, u, v, w, 0};

    auto root = move(deg);
    fill(all(root), -1);
    for (int l = 0; l < m;) {
        root[heap[l].to] = l;
        int r = l + 1;
        while (r < m && heap[r].to == heap[l].to)
            ++r;

        make_heap(begin(heap) + l, begin(heap) + r, [&](const auto& v1, const auto& v2) {
            return v1.weight > v2.weight;
        });

        rep(i, 2, r - l + 1)
            (i % 2 ? heap[l - 1 + i / 2].r : heap[l - 1 + i / 2].l) = l - 1 + i;

        l = r;
    }

    return run_solve(n, vr, move(heap), move(root));
}

int main() {
	int T; read(T);
	while(T--){
		int n, m; read(n, m);
		vector edges(m, array{0, 0, 0});
		for (auto& [u, v, w] : edges){
			read(u, v, w); u--,v--;
		}

		auto [cost, sol_edges] = solve_new(n, 0, edges);
		println(cost);
	}
}

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

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

3
5 6
1 2 4
1 3 2
2 3 0
3 4 1
4 5 1
5 2 1
4 4
1 2 4
1 3 6
1 4 8
4 2 1000000
3 3
1 2 100
2 1 10
2 3 1000

output:

5
18
1100

result:

ok 3 number(s): "5 18 1100"

Test #2:

score: 0
Accepted
time: 20ms
memory: 5136kb

input:

50000
4 5
2 4 998973548
2 3 501271695
4 1 778395982
1 4 32454891
1 2 757288934
4 5
1 4 720856669
2 3 665098951
3 4 407461517
2 1 866914401
1 2 457859826
4 5
1 2 75288664
1 4 624893594
3 2 458973866
2 4 769074655
2 3 834773751
4 5
2 3 237060634
2 4 297307882
3 4 200383586
1 2 42856502
3 1 16574713
4 ...

output:

1291015520
1530420294
1534956009
480300722
1366795927
1541095843
2493849488
858095911
1034153425
793861088
605832428
1051598350
612891589
1265994009
517769091
1678219738
1556463491
93634961
960978736
984886788
1696503797
1002892611
1969660290
1431417780
1515267731
977157479
1937478556
654475526
1401...

result:

ok 50000 numbers

Test #3:

score: 0
Accepted
time: 21ms
memory: 5500kb

input:

50000
4 6
1 3 754771977
2 3 517886121
1 4 392356144
1 2 702785740
3 4 888230940
2 1 829304957
4 6
2 4 255940037
1 2 380616616
1 4 819140865
3 4 36965607
1 3 496378345
4 3 652252309
4 6
2 4 179216787
4 2 401136502
1 2 715271531
1 3 859345710
3 4 24470489
1 4 148650889
4 6
3 2 20348069
1 2 152861663
1...

output:

1613028005
913960568
1284952701
1294564551
199037829
1236121455
983447828
1161647829
1289612543
2444304029
431872921
1272140390
949528400
2328941976
696541797
363553357
999320657
2221495861
879052116
1287531701
912524980
1072419431
1187727045
1571845059
1184110956
1136184594
430092563
1132894799
962...

result:

ok 50000 numbers

Test #4:

score: 0
Accepted
time: 9ms
memory: 5056kb

input:

25000
8 8
5 3 903349949
5 6 230898386
6 7 456285865
2 3 235279998
3 8 75554555
1 2 534445049
2 5 91984463
3 4 930308596
8 8
4 8 542820075
2 1 505042427
1 2 383870408
1 4 115526736
2 5 120351002
4 7 303640587
2 3 343568518
1 6 643773351
8 8
1 2 362133720
1 3 865161709
2 4 418085685
2 5 431348178
1 6 ...

output:

2554756912
2453550677
3352164037
2548011007
2946870949
2974098273
3702415713
3077518439
3933251840
3561133042
3661712043
3019312810
3492992897
3247019175
2091050366
3228447489
4450182982
4547489101
2740661646
3507248157
3421959708
3851505640
4373872101
3925763540
4160440497
2854028840
2797343113
338...

result:

ok 25000 numbers

Test #5:

score: 0
Accepted
time: 14ms
memory: 4832kb

input:

25000
8 9
1 3 8441923
2 8 804745873
1 4 814834377
1 5 576030519
8 5 953473409
2 6 714140471
2 5 77120962
1 2 511057482
4 7 145441656
8 9
1 2 276813465
4 5 165256724
1 4 522691074
1 7 417909938
1 8 962962225
1 3 805076553
2 6 623033783
8 4 647061395
3 4 815842049
8 9
3 5 20296808
3 6 597281111
1 2 76...

output:

3075782744
3773743762
3278650492
3231838190
3374994424
2926778533
4348233362
2822143392
3076722255
2596140564
2247390371
3854832394
4319882601
3180102719
3094944789
3435791714
4405129128
2340656122
2604427605
3572178751
3803314864
3351077905
3767890679
3567633269
3527865042
2895660631
3817016063
188...

result:

ok 25000 numbers

Test #6:

score: 0
Accepted
time: 16ms
memory: 4952kb

input:

25000
8 10
7 4 221904276
1 5 121915318
1 3 600836161
4 7 488300065
1 4 921802874
1 2 757229498
2 3 307033253
3 6 824028669
1 7 171060397
3 8 972502017
8 10
3 5 957779273
1 2 548128903
1 3 973419517
6 5 565445547
3 6 551907938
1 7 793064110
7 8 466118245
1 4 353130404
5 6 927135859
2 8 758403259
8 10...

output:

3375673428
4251214664
3757000574
3166584844
2788975514
2116310775
2715058780
3287246298
4025635987
3624892566
2769498633
2958022862
4290202794
2920552027
3277314894
3924975405
3237273140
2821648429
2360729796
3475710401
3972691777
4115444652
2692775193
3118467245
3132060418
2872337367
4722221967
264...

result:

ok 25000 numbers

Test #7:

score: 0
Accepted
time: 18ms
memory: 4956kb

input:

25000
8 12
2 6 449032103
1 5 646093619
7 8 888519232
2 4 749443783
4 5 475422884
1 2 434507939
6 7 525256368
3 7 280175107
6 4 267731039
2 3 727214343
5 7 91009177
1 6 499664950
8 12
4 6 657574176
1 2 5296179
5 7 312584650
3 4 999483683
2 3 491085057
2 5 719151963
7 2 741976162
1 4 636522791
1 6 458...

output:

3333436717
2807585131
4920461769
3090434252
2560790821
2380624756
2626592068
3772048085
2624368713
1844640463
2565437000
2622643735
2416136939
2618783813
2813654707
3205164529
3974831765
3722108973
2648137059
3165927114
2050934228
3202220845
3802856334
3396453248
2597210524
3975316045
2920520206
301...

result:

ok 25000 numbers

Test #8:

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

input:

200
1000 1000
239 588 133547926
183 534 928409215
241 330 641475654
535 957 589849559
10 620 614874088
309 928 569710487
3 11 494917111
543 890 68083403
400 918 317003458
251 321 376382937
147 160 903343522
452 924 589468457
20 197 468355859
108 599 820206568
230 378 910782377
220 293 903007367
115 ...

output:

497713793250
492962928026
507239162096
489416880760
498919499738
494390387999
505624748297
502273360170
487437969890
492882286087
488855359914
493516382821
492154885694
494693728666
501962518846
492234657903
499522656353
518342153867
494724608349
500831455708
498690702121
494557144727
503463772263
5...

result:

ok 200 numbers

Test #9:

score: 0
Accepted
time: 9ms
memory: 4672kb

input:

200
1000 1005
508 559 424192332
74 278 148045823
327 993 663345255
157 544 928557499
20 41 523494941
51 254 437200278
2 18 506681783
782 928 138677470
12 838 503910272
156 645 862366636
200 508 218413621
231 635 194448744
611 619 124981290
255 469 614512720
134 333 818641028
181 412 921437717
5 184 ...

output:

501129145945
508207765375
504606717649
501142420466
496433756584
508422487274
507007286774
489195446348
499101136725
504420343219
485311666315
489123709490
499113103288
496900542557
481508383246
492384657383
496513770885
509736025057
495760467649
497002983791
491910563136
494017531362
498058386677
4...

result:

ok 200 numbers

Test #10:

score: 0
Accepted
time: 18ms
memory: 4772kb

input:

200
1000 2000
39 238 864415857
26 156 707268612
146 546 499579162
417 761 332452795
10 410 961630809
587 745 361841763
131 716 968927701
834 888 74441039
142 781 613126744
221 273 614239182
900 945 849004495
668 938 475774163
297 748 413513365
679 862 473286635
262 523 476328885
852 977 55421955
256...

output:

377088491179
368197541228
378166264449
385285967410
363829015221
378666687744
376662529392
383676533289
374782208099
373676435135
373318306315
377833081332
386724232469
362733514349
384542854056
376214712692
376322456811
374258497868
379984477018
375276245615
384876693250
369634790945
375323862443
3...

result:

ok 200 numbers

Test #11:

score: 0
Accepted
time: 21ms
memory: 4744kb

input:

160
1000 3000
361 390 785950892
564 577 524217752
334 931 11528988
228 304 70325077
694 747 1928318
474 945 249706711
239 912 124894561
736 834 191207404
215 303 773416167
182 763 70656237
454 457 937174144
346 568 535198270
666 676 739691416
478 631 580490353
263 625 449713668
64 907 740013425
44 2...

output:

299833687308
304977657092
307270423217
294716038190
309503138234
305635005136
310814442139
312934222331
299600885716
305288964059
308283739944
300775461259
301205352773
309409716517
296295870502
294594618853
299117813318
295956044320
300467617156
305256736121
305862015525
314513636581
294398803135
2...

result:

ok 160 numbers

Test #12:

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

input:

1
1000 100000
50 415 104868280
691 700 424553918
111 968 56214986
269 529 173077590
52 117 925712505
535 560 991283286
444 729 923471207
917 964 567645976
122 305 958342700
682 945 719398103
383 527 201210989
304 318 705615051
152 926 526523918
18 527 542190718
253 593 892670139
688 706 379199924
57...

output:

23974268933

result:

ok 1 number(s): "23974268933"

Test #13:

score: 0
Accepted
time: 11ms
memory: 15036kb

input:

1
200000 200000
46957 87435 612302422
91840 173370 891722968
25009 74170 884361660
74176 99042 131797405
16139 58764 648773820
58722 191045 349784377
24095 72719 77508332
7510 25316 299592819
51067 124120 258305363
65132 104676 752760402
19337 21868 193391749
21056 155761 223617084
69406 105016 6650...

output:

100416224076541

result:

ok 1 number(s): "100416224076541"

Test #14:

score: 0
Accepted
time: 10ms
memory: 15168kb

input:

1
200000 200005
18188 18759 447257093
23283 144020 296580050
31611 45965 223988792
38100 119202 291195007
101055 137132 899526750
5591 49075 27414736
56949 151097 671413227
41985 47180 503110244
30438 46109 460979545
86928 117978 250704533
12466 168536 241962293
136066 184729 200523801
8327 161157 9...

output:

99973876572792

result:

ok 1 number(s): "99973876572792"

Test #15:

score: 0
Accepted
time: 11ms
memory: 18660kb

input:

1
200000 300000
155561 161597 537100897
126654 128124 199395618
71901 163500 259430846
142983 177985 36516674
51299 136136 392555170
27776 129030 599861396
196834 199267 608694287
10521 128879 579122252
53483 134123 144345200
101992 194707 710827766
9703 25975 222504051
40022 110651 509241864
6002 1...

output:

85802950605768

result:

ok 1 number(s): "85802950605768"

Test #16:

score: 0
Accepted
time: 28ms
memory: 22096kb

input:

1
200000 400000
83662 178071 426605522
11425 16196 19198021
143760 158308 516994131
32332 137595 862193296
49812 100060 500080963
158302 197705 152597027
31283 167752 375247059
3021 147864 874473750
79941 123131 80284324
18754 41021 30099126
20756 24387 802117779
9987 18379 197504832
8515 74052 3263...

output:

74861108824752

result:

ok 1 number(s): "74861108824752"

Test #17:

score: 0
Accepted
time: 24ms
memory: 25608kb

input:

1
200000 500000
62168 161948 861315677
112229 161852 761794094
128601 154379 526739829
62695 103637 61569219
19608 75157 292208612
126437 175609 209327426
25587 79963 853866912
40042 44741 263511253
30517 34613 381707399
159474 165977 476693969
3904 15167 805558096
4833 111840 366578074
128426 17895...

output:

66967278157139

result:

ok 1 number(s): "66967278157139"

Test #18:

score: 0
Accepted
time: 7ms
memory: 15032kb

input:

1
200000 200000
7705 8241 520782023
140531 152029 687751641
43264 43888 88402484
54060 58780 817256981
61134 74809 551055996
100583 102620 123923634
9996 11024 737292575
198215 199660 566035520
96585 97536 885236471
114899 132213 221385275
170689 175281 627663929
180974 186141 442048655
120175 15473...

output:

100188105214556

result:

ok 1 number(s): "100188105214556"

Test #19:

score: 0
Accepted
time: 14ms
memory: 15084kb

input:

1
200000 200005
68401 74132 160698844
187044 189608 214949848
197114 199326 731815192
21500 25787 694526736
72033 81952 662360391
170641 172214 362037286
156862 172151 269149013
167411 181793 485470522
147746 159804 53837947
43787 45836 194536765
107166 126965 995308582
90107 94644 185953754
21302 2...

output:

100120940177490

result:

ok 1 number(s): "100120940177490"

Test #20:

score: 0
Accepted
time: 14ms
memory: 18692kb

input:

1
200000 300000
3766 4420 373137267
116036 129195 111247661
158144 170951 883057839
61382 68089 579290706
155588 166293 639500940
136406 179216 133474469
145859 171162 167954305
116225 135112 893968344
157383 174339 956803896
59509 67116 474880072
39651 47978 385032783
67676 85713 838220071
163721 1...

output:

85256632478195

result:

ok 1 number(s): "85256632478195"

Test #21:

score: 0
Accepted
time: 23ms
memory: 22104kb

input:

1
200000 400000
120297 140098 772198011
86363 126850 879623867
120477 123540 876304344
15296 16334 590170479
169871 181898 944491242
43035 46717 562613837
16508 18292 851791484
154898 158279 489139310
145251 155084 476130469
113377 115752 830065223
160400 182101 26650956
124897 125084 88183981
18538...

output:

73541046939260

result:

ok 1 number(s): "73541046939260"

Test #22:

score: 0
Accepted
time: 25ms
memory: 25696kb

input:

1
200000 500000
17689 19395 636032584
47913 49021 217092704
90476 110562 195492702
39863 41431 281615032
115069 143751 314738997
23708 25663 329197380
128813 130925 192554235
645 680 816846550
1969 2121 51390939
25236 27260 713563693
44560 44638 811933389
110269 111129 138311338
112006 115788 436965...

output:

64199493931930

result:

ok 1 number(s): "64199493931930"

Test #23:

score: 0
Accepted
time: 10ms
memory: 14988kb

input:

1
200000 200000
80923 81029 524356932
80777 81322 605975208
184683 186275 511713894
5917 5938 478973783
197707 197912 303672471
73721 74157 121235054
80826 81371 552549792
98108 99370 613814545
20757 20782 448907956
68931 68980 465325373
105058 105507 628437785
104451 111530 579179066
50238 50753 74...

output:

99901846611220

result:

ok 1 number(s): "99901846611220"

Test #24:

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

input:

1
200000 200005
48493 48642 67041357
13578 13747 514196450
5314 5351 54673115
177461 177648 417598945
1808 1821 540881041
18745 19169 168351085
138012 138933 885329970
54521 55109 981243371
120191 120959 368416696
67553 68637 543072779
68075 68803 284380976
117151 117294 713725709
60563 61206 451262...

output:

100264161731102

result:

ok 1 number(s): "100264161731102"

Test #25:

score: 0
Accepted
time: 21ms
memory: 18700kb

input:

1
200000 300000
166609 167016 587242124
193258 195045 344428600
112992 113328 43936408
98523 98677 58792970
82293 82716 229371569
188501 189243 337557797
67991 68182 10327565
9518 9544 657592307
194099 196210 213308091
56407 56422 218843837
8971 8989 230154910
17681 17693 709463873
160780 163313 279...

output:

85348869587517

result:

ok 1 number(s): "85348869587517"

Test #26:

score: 0
Accepted
time: 27ms
memory: 22072kb

input:

1
200000 400000
35822 36031 37445407
130090 130772 163956334
54587 55569 914232449
148780 149450 259545195
126271 126300 885223403
172210 178812 909477395
166085 169466 260617947
98156 99224 97231363
135774 136578 390039658
132852 135039 884583524
186283 188032 922966484
159621 159986 11191276
1688 ...

output:

73713197570980

result:

ok 1 number(s): "73713197570980"

Test #27:

score: 0
Accepted
time: 29ms
memory: 25468kb

input:

1
200000 500000
51320 51572 662167325
76775 76862 535691105
20391 20592 831708520
116583 117444 835966021
91215 92257 327070610
101100 101762 526326742
5298 5445 707609181
73148 73313 331570053
11938 11980 110099761
14425 14459 702112118
13228 13286 53807245
83770 84606 42176590
101233 102925 549097...

output:

64270762326141

result:

ok 1 number(s): "64270762326141"

Test #28:

score: 0
Accepted
time: 10ms
memory: 15140kb

input:

1
200000 200000
109027 109045 29657209
25311 25331 280961282
15095 15096 879526875
171564 171657 801110244
198332 198558 943050198
38494 38528 759506849
52455 52526 668548339
150882 150977 821764892
166105 166162 784202684
962 963 993558513
73056 73199 720161632
107230 107282 121813839
80656 80689 4...

output:

100037565344404

result:

ok 1 number(s): "100037565344404"

Test #29:

score: 0
Accepted
time: 9ms
memory: 15060kb

input:

1
200000 200005
181668 181970 256436018
16858 16889 551412058
13501 13514 558870752
154981 155034 570222145
107709 107754 505544303
142566 142869 557172835
142867 143064 368193769
148036 148180 22660988
140714 140811 403909345
139977 139987 678168620
42532 42542 365052250
9338 9340 962914929
194309 ...

output:

100025983988963

result:

ok 1 number(s): "100025983988963"

Test #30:

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

input:

1
200000 300000
73041 73113 581820575
124415 124420 186481965
20265 20288 1071939
40389 40405 835224034
125528 125636 797450403
160939 160983 370147964
91783 91842 750913005
197184 197371 405772521
151401 151445 157054880
149686 149833 391201188
26449 26501 18657228
18818 18827 958150699
177940 1783...

output:

85291269052887

result:

ok 1 number(s): "85291269052887"

Test #31:

score: 0
Accepted
time: 23ms
memory: 22224kb

input:

1
200000 400000
47378 47429 578077719
9721 9726 429698372
181340 181603 729830543
197008 197296 663731549
136994 137019 845581874
85933 86061 972778899
189781 189797 213229077
130366 130450 345935722
119008 119048 626284190
113970 114092 53011626
171235 172369 145052487
17458 17465 36987879
55632 55...

output:

73380839092975

result:

ok 1 number(s): "73380839092975"

Test #32:

score: 0
Accepted
time: 32ms
memory: 25596kb

input:

1
200000 500000
96144 96249 622408076
17836 17859 524402519
89256 89348 242208619
147257 147318 43829213
133567 134005 313841350
103337 103382 480312838
135833 135873 222000122
78828 78870 768481944
61550 61551 572897176
162678 162681 757368039
94915 94959 756597494
51612 51734 611865481
39128 39144...

output:

64462851310914

result:

ok 1 number(s): "64462851310914"

Test #33:

score: 0
Accepted
time: 9ms
memory: 5512kb

input:

50000
4 3
1 3 167546739
4 2 150857696
1 4 51822807
4 3
3 4 741947573
1 3 900930191
3 2 716723012
4 3
1 2 606602779
2 4 794357869
4 3 982330970
4 3
4 3 742422989
2 4 962488692
1 2 664418620
4 3
1 4 320523247
4 2 225529023
2 3 338428848
4 3
3 4 231873383
3 2 240654393
1 3 81010550
4 3
1 3 426126443
3 ...

output:

370227242
2359600776
2383291618
2369330301
884481118
553538326
1420658934
1814790060
1636487543
1625309596
537349036
1752280381
1249143448
549697074
1738714045
1345620195
1811746234
1252016344
1559184113
1226822537
1088508425
1818607345
1543000967
1337019778
1710917587
1088615291
1419525376
21451014...

result:

ok 50000 numbers

Test #34:

score: 0
Accepted
time: 17ms
memory: 5088kb

input:

50000
4 4
2 4 485320476
1 4 533450041
4 2 319952928
1 3 269856374
4 4
1 3 452037325
3 4 252046806
3 2 108668947
1 4 702697785
4 4
1 4 982764378
2 3 426870264
1 3 472629382
3 2 484156411
4 4
3 2 428121575
1 4 277038145
2 3 137238069
1 3 58434493
4 4
1 4 797910962
1 3 154041077
3 2 915317132
3 4 53737...

output:

1123259343
812753078
1939550171
763594213
1606730270
1448384708
1435840093
1699368485
1622990666
1747635458
1647077177
349083873
1601005199
1200044124
1600897111
493715120
1973105265
830347364
1558171519
980872483
1159889496
1381564020
328673314
1494838829
1650465558
1706597072
2127639661
1293806849...

result:

ok 50000 numbers

Test #35:

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

input:

25000
8 7
8 3 417672786
1 2 21599197
2 7 61579086
2 6 862219611
1 4 516000641
6 8 601340576
3 5 892390154
8 7
1 5 102331144
2 7 484753283
2 6 522435371
6 8 137433435
2 4 993724737
1 2 438850997
7 3 41337395
8 7
4 3 326951219
2 5 175677503
1 4 614088417
1 2 252626863
7 8 692045913
4 6 360768250
2 7 8...

output:

3372802051
2720866362
3237880700
3810489512
3163461285
2980909825
2497241195
4090447512
4264446156
2943400684
3548026729
2420754310
2365262718
4188235331
3520414128
4758682762
2773003934
2465478547
4364902299
2837089453
3980312414
3458096134
3668063420
3466320984
3919574776
3178155812
1163610755
344...

result:

ok 25000 numbers

Test #36:

score: 0
Accepted
time: 13ms
memory: 4832kb

input:

25000
8 8
5 7 375094477
7 8 769543890
2 7 707354643
3 5 628065900
6 3 778318389
1 2 383550183
2 4 67982839
2 6 712762154
8 8
1 4 297445036
2 3 285256662
5 6 978013234
2 8 542820075
7 5 505042427
1 7 383870408
5 7 115526736
1 2 120351002
8 8
2 4 345546344
4 3 351133479
3 8 514308318
1 2 296143723
1 7...

output:

3715317832
3112798844
3755001532
2140411228
2700362971
2186342994
3896569954
2132226777
3445117101
3465410138
2859847239
2408820715
3223347980
3778898852
2955287724
1944512002
3548828964
4383818182
3641963929
3051486943
2643741932
3868672738
2981172535
3907338071
2661285694
2713366806
3681283222
332...

result:

ok 25000 numbers

Test #37:

score: 0
Accepted
time: 15ms
memory: 5176kb

input:

25000
8 9
4 2 761783123
2 5 17701951
3 8 571579765
1 3 262371757
3 4 435405018
6 7 662031263
4 7 321235114
5 6 956940778
6 8 856956563
8 9
2 4 984142283
1 3 443374148
2 6 506090462
1 2 405150481
1 5 126966728
1 7 276813465
4 3 165256724
7 8 522691074
3 8 417909938
8 9
7 2 299749140
1 4 727560020
3 6...

output:

3327017506
2882330081
3426436450
4856161143
1879345413
3924723627
2647475196
3597544154
2178732948
2991736985
2395259141
4258373242
3382943601
3413055622
3658065595
4195466826
3142022188
3050154576
3791986456
2889786725
3095576517
3022313317
3849655118
3249674750
3274732038
4131442253
3590848569
313...

result:

ok 25000 numbers

Test #38:

score: 0
Accepted
time: 18ms
memory: 5244kb

input:

25000
8 11
4 5 310801016
2 8 700412776
2 7 575120738
1 6 662936070
5 7 101970652
1 7 561178187
7 8 659200472
1 3 461223325
3 8 771048446
7 4 93795527
1 2 663341690
8 11
2 7 624226516
3 2 176804348
4 8 869811223
3 5 916207526
1 6 154691972
1 8 417052757
3 4 695860133
4 6 5171117
1 4 78421142
2 5 6608...

output:

3412476287
2031617994
2820462564
2555690868
3845528096
1273250868
3098877990
2849186057
3182065247
2548093060
3518810555
3407443473
2451021494
2900232001
2866666591
2476690805
3925732207
2837088589
4397396382
2705803951
2445581559
2331879819
2017519570
3011831045
2761773268
2545427756
2522458267
421...

result:

ok 25000 numbers

Test #39:

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

input:

200
1000 999
153 191 812234900
4 812 805855607
501 697 81669222
6 19 537590112
147 174 259281585
291 481 948109379
210 667 447645532
22 76 523130229
87 175 386067019
355 989 91593819
98 565 557738562
423 509 581708416
97 427 315550000
324 415 177404725
582 952 988308863
88 92 118563568
653 944 75412...

output:

516210868701
500339147372
499336387214
500539140603
498277310242
501870128789
516228220710
508179784194
500776602836
497921242835
492919477612
495198969705
500151411686
512678232127
498609680007
504703943889
514312309809
512391082080
501851666944
481485579079
490997584532
508254990586
493265314887
4...

result:

ok 200 numbers

Test #40:

score: 0
Accepted
time: 9ms
memory: 4668kb

input:

200
1000 1005
30 863 88714823
18 487 884033017
446 601 94705715
287 399 930520432
110 623 185303672
175 716 461853320
173 740 167694455
51 388 994769338
413 717 132438568
133 536 989798918
595 628 309881536
33 52 361860779
394 469 739975952
144 443 428165502
501 679 434395305
8 116 964768906
8 135 4...

output:

499171023112
508247421841
494457943827
499166461193
477831858402
510198184897
501804599018
489912613342
489180161029
503800514596
486384289058
491062931450
505956389976
496889211807
493521306241
495410180959
493455590717
505937787970
488658178149
493755547582
495860086984
495732583229
507614091903
4...

result:

ok 200 numbers

Test #41:

score: 0
Accepted
time: 18ms
memory: 4868kb

input:

200
1000 2000
361 390 827591830
776 839 47585307
84 230 644671754
240 419 989930465
740 767 495679446
269 607 772800035
304 547 213438009
213 519 701983575
425 464 660810298
417 456 988214235
87 215 305020871
320 926 840004627
120 747 355654476
31 232 912637512
51 159 299956132
17 618 639032414
318 ...

output:

383264959941
369564727089
378612881846
382862197562
369852605474
367664869812
369757573260
384444446217
377763334234
362860580014
377731652539
374173469154
377012364838
370185687604
361210221600
376497722261
382926313386
374481201293
381083586313
365302024664
373866228764
371915926020
381473367099
3...

result:

ok 200 numbers

Test #42:

score: 0
Accepted
time: 21ms
memory: 4684kb

input:

160
1000 3000
556 901 34261241
573 644 723615271
28 181 908355673
275 590 582558653
573 747 733152694
18 66 693688759
24 144 901311736
306 707 473045371
246 529 702959712
366 834 646714632
80 98 74112310
484 909 572977284
525 852 76259604
62 850 802999350
214 303 870204914
627 736 802553249
623 656 ...

output:

304910800107
307628976455
304898878892
293579559666
291599757403
295646210367
306439275874
307217061544
300432691868
294203617397
300889778850
304860267359
311398063102
301357064304
297677185405
300084426829
296586536032
312172515661
296778189964
305189643184
306356515331
310555718052
294050306345
3...

result:

ok 160 numbers

Test #43:

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

input:

1
3 2
3 2 0
1 3 1000000000

output:

1000000000

result:

ok 1 number(s): "1000000000"

Extra Test:

score: 0
Extra Test Passed