QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#555485#9252. Penguins in Refrigeratorucup-team3099AC ✓2007ms146724kbC++2014.4kb2024-09-10 00:28:302024-09-10 00:28:30

Judging History

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

  • [2024-09-10 00:28:30]
  • 评测
  • 测评结果:AC
  • 用时:2007ms
  • 内存:146724kb
  • [2024-09-10 00:28:30]
  • 提交

answer

#ifdef LOCAL
#define _GLIBCXX_DEBUG 1
#define dbg(...) cerr << "LINE(" << __LINE__ << ") -> [" << #__VA_ARGS__ << "]: [", DBG(__VA_ARGS__)
#else
#define dbg(...) 0
#endif

#if 0
    #include <ext/pb_ds/assoc_container.hpp>
    #include <ext/pb_ds/tree_policy.hpp>
 
    template<class T>
    using ordered_set = __gnu_pbds::tree<T, __gnu_pbds::null_type, std::less<T>, __gnu_pbds::rb_tree_tag,
        __gnu_pbds::tree_order_statistics_node_update>;
#endif

#include <vector> 
#include <list> 
#include <map> 
#include <set> 
#include <queue>
#include <stack> 
#include <bitset> 
#include <algorithm> 
#include <numeric> 
#include <utility> 
#include <sstream> 
#include <iostream> 
#include <iomanip> 
#include <cstdio> 
#include <cmath> 
#include <cstdlib> 
#include <ctime> 
#include <cstring>
#include <random>
#include <chrono>
#include <cassert>
#include <functional>

using namespace std;
 
#define rep(i, a, b) for(int i = a; i < (b); ++i)
#define sz(x) (int)(x).size()
#define all(x) begin(x), end(x)
#define FOR(i,a,b) for (int i = (a); i < (b); ++i)
#define F0R(i,a) FOR(i,0,a)
#define REP(i,n) for(int (i)=0;(i)<(int)(n);(i)++)

#define each(a,x) for (auto& a: x)
#define tcT template<class T
#define tcTU tcT, class U
#define tcTUU tcT, class ...U
template<class T> using V = vector<T>; 
template<class T, size_t SZ> using AR = array<T,SZ>;

typedef string str;
typedef long long ll;
typedef pair<int, int> pii;
typedef vector<int> vi;
typedef vector<vi> vvi;
 
template<typename T, typename U> T &ctmax(T &x, const U &y){ return x = max<T>(x, y); }
template<typename T, typename U> T &ctmin(T &x, const U &y){ return x = min<T>(x, y); }
 
mt19937 rng((unsigned)chrono::steady_clock::now().time_since_epoch().count());
 
#define ts to_string
str ts(char c) { return str(1,c); }
str ts(bool b) { return b ? "true" : "false"; }
str ts(const char* s) { return (str)s; }
str ts(str s) { return s; }
str ts(vector<bool> v) { str res = "{"; F0R(i,sz(v)) res += char('0'+v[i]);	res += "}"; return res; }
template<size_t SZ> str ts(bitset<SZ> b) { str res = ""; F0R(i,SZ) res += char('0'+b[i]); return res; }
template<class A, class B> str ts(pair<A,B> p);
template<class T> str ts(T v) { bool fst = 1; str res = "{"; for (const auto& x: v) {if (!fst) res += ", ";	fst = 0; res += ts(x);}	res += "}"; return res;}
template<class A, class B> str ts(pair<A,B> p) {return "("+ts(p.first)+", "+ts(p.second)+")"; }
 
template<class A> void pr(A x) { cout << ts(x); }
template<class H, class... T> void pr(const H& h, const T&... t) { pr(h); pr(t...); }
void ps() { pr("\n"); }
template<class H, class... T> void ps(const H& h, const T&... t) { pr(h); if (sizeof...(t)) pr(" "); ps(t...); }
 
void DBG() { cerr << "]" << endl; }
template<class H, class... T> void DBG(H h, T... t) {cerr << ts(h); if (sizeof...(t)) cerr << ", ";	DBG(t...); }

tcTU> void re(pair<T,U>& p);
tcT> void re(V<T>& v);
tcT, size_t SZ> void re(AR<T,SZ>& a);

tcT> void re(T& x) { cin >> x; }
void re(double& d) { str t; re(t); d = stod(t); }
void re(long double& d) { str t; re(t); d = stold(t); }
tcTUU> void re(T& t, U&... u) { re(t); re(u...); }

tcTU> void re(pair<T,U>& p) { re(p.first,p.second); }
tcT> void re(V<T>& x) { each(a,x) re(a); }
tcT, size_t SZ> void re(AR<T,SZ>& x) { each(a,x) re(a); }
tcT> void rv(int n, V<T>& x) { x.rsz(n); re(x); }

constexpr bool multitest() {return 0;}
void solve();
int main() {
	ios_base::sync_with_stdio(false); cin.tie(NULL);
	int t = 1;
	if (multitest()) cin >> t;
	for (; t; t--) solve();
}





template<int MOD> struct mint {
	static const int mod = MOD;
	int v; explicit operator int() const { return v; } // explicit -> don't silently convert to int
	mint():v(0) {}
	mint(ll _v) { v = int((-MOD < _v && _v < MOD) ? _v : _v % MOD);
		if (v < 0) v += MOD; }
	bool operator==(const mint& o) const {
		return v == o.v; }
	friend bool operator!=(const mint& a, const mint& b) { 
		return !(a == b); }
	friend bool operator<(const mint& a, const mint& b) { 
		return a.v < b.v; }
	friend str ts(mint a) { return ts(a.v); }
   
	mint& operator+=(const mint& o) { 
		if ((v += o.v) >= MOD) v -= MOD; 
		return *this; }
	mint& operator-=(const mint& o) { 
		if ((v -= o.v) < 0) v += MOD; 
		return *this; }
	mint& operator*=(const mint& o) { 
		v = int((ll)v*o.v%MOD); return *this; }
	mint& operator/=(const mint& o) { return (*this) *= inv(o); }
	friend mint pow(mint a, ll p) {
		mint ans = 1; assert(p >= 0);
		for (; p; p /= 2, a *= a) if (p&1) ans *= a;
		return ans; }
	friend mint inv(const mint& a) { assert(a.v != 0); 
		return pow(a,MOD-2); }
		
	mint operator-() const { return mint(-v); }
	mint& operator++() { return *this += 1; }
	mint& operator--() { return *this -= 1; }
	friend mint operator+(mint a, const mint& b) { return a += b; }
	friend mint operator-(mint a, const mint& b) { return a -= b; }
	friend mint operator*(mint a, const mint& b) { return a *= b; }
	friend mint operator/(mint a, const mint& b) { return a /= b; }
};

using mi = mint<1000000007>;

namespace atcoder {

namespace internal {

#if __cplusplus >= 202002L

using std::bit_ceil;

#else

// @return same with std::bit::bit_ceil
unsigned int bit_ceil(unsigned int n) {
    unsigned int x = 1;
    while (x < (unsigned int)(n)) x *= 2;
    return x;
}

#endif

// @param n `1 <= n`
// @return same with std::bit::countr_zero
int countr_zero(unsigned int n) {
#ifdef _MSC_VER
    unsigned long index;
    _BitScanForward(&index, n);
    return index;
#else
    return __builtin_ctz(n);
#endif
}

// @param n `1 <= n`
// @return same with std::bit::countr_zero
constexpr int countr_zero_constexpr(unsigned int n) {
    int x = 0;
    while (!(n & (1 << x))) x++;
    return x;
}

}  // namespace internal

#if __cplusplus >= 201703L

template <class S,
          auto op,
          auto e,
          class F,
          auto mapping,
          auto composition,
          auto id>
struct lazy_segtree {
    static_assert(std::is_convertible_v<decltype(op), std::function<S(S, S)>>,
                  "op must work as S(S, S)");
    static_assert(std::is_convertible_v<decltype(e), std::function<S()>>,
                  "e must work as S()");
    static_assert(
        std::is_convertible_v<decltype(mapping), std::function<S(F, S)>>,
        "mapping must work as F(F, S)");
    static_assert(
        std::is_convertible_v<decltype(composition), std::function<F(F, F)>>,
        "compostiion must work as F(F, F)");
    static_assert(std::is_convertible_v<decltype(id), std::function<F()>>,
                  "id must work as F()");

#else

template <class S,
          S (*op)(S, S),
          S (*e)(),
          class F,
          S (*mapping)(F, S),
          F (*composition)(F, F),
          F (*id)()>
struct lazy_segtree {

#endif

  public:
    lazy_segtree() : lazy_segtree(0) {}
    explicit lazy_segtree(int n) : lazy_segtree(std::vector<S>(n, e())) {}
    explicit lazy_segtree(const std::vector<S>& v) : _n(int(v.size())) {
        size = (int)internal::bit_ceil((unsigned int)(_n));
        log = internal::countr_zero((unsigned int)size);
        d = std::vector<S>(2 * size, e());
        lz = std::vector<F>(size, id());
        for (int i = 0; i < _n; i++) d[size + i] = v[i];
        for (int i = size - 1; i >= 1; i--) {
            update(i);
        }
    }

    void set(int p, S x) {
        assert(0 <= p && p < _n);
        p += size;
        for (int i = log; i >= 1; i--) push(p >> i);
        d[p] = x;
        for (int i = 1; i <= log; i++) update(p >> i);
    }

    S get(int p) {
        assert(0 <= p && p < _n);
        p += size;
        for (int i = log; i >= 1; i--) push(p >> i);
        return d[p];
    }

    S prod(int l, int r) {
        assert(0 <= l && l <= r && r <= _n);
        if (l == r) return e();

        l += size;
        r += size;

        for (int i = log; i >= 1; i--) {
            if (((l >> i) << i) != l) push(l >> i);
            if (((r >> i) << i) != r) push((r - 1) >> i);
        }

        S sml = e(), smr = e();
        while (l < r) {
            if (l & 1) sml = op(sml, d[l++]);
            if (r & 1) smr = op(d[--r], smr);
            l >>= 1;
            r >>= 1;
        }

        return op(sml, smr);
    }

    S all_prod() { return d[1]; }

    void apply(int p, F f) {
        assert(0 <= p && p < _n);
        p += size;
        for (int i = log; i >= 1; i--) push(p >> i);
        d[p] = mapping(f, d[p]);
        for (int i = 1; i <= log; i++) update(p >> i);
    }
    void apply(int l, int r, F f) {
        assert(0 <= l && l <= r && r <= _n);
        if (l == r) return;

        l += size;
        r += size;

        for (int i = log; i >= 1; i--) {
            if (((l >> i) << i) != l) push(l >> i);
            if (((r >> i) << i) != r) push((r - 1) >> i);
        }

        {
            int l2 = l, r2 = r;
            while (l < r) {
                if (l & 1) all_apply(l++, f);
                if (r & 1) all_apply(--r, f);
                l >>= 1;
                r >>= 1;
            }
            l = l2;
            r = r2;
        }

        for (int i = 1; i <= log; i++) {
            if (((l >> i) << i) != l) update(l >> i);
            if (((r >> i) << i) != r) update((r - 1) >> i);
        }
    }

    template <bool (*g)(S)> int max_right(int l) {
        return max_right(l, [](S x) { return g(x); });
    }
    template <class G> int max_right(int l, G g) {
        assert(0 <= l && l <= _n);
        assert(g(e()));
        if (l == _n) return _n;
        l += size;
        for (int i = log; i >= 1; i--) push(l >> i);
        S sm = e();
        do {
            while (l % 2 == 0) l >>= 1;
            if (!g(op(sm, d[l]))) {
                while (l < size) {
                    push(l);
                    l = (2 * l);
                    if (g(op(sm, d[l]))) {
                        sm = op(sm, d[l]);
                        l++;
                    }
                }
                return l - size;
            }
            sm = op(sm, d[l]);
            l++;
        } while ((l & -l) != l);
        return _n;
    }

    template <bool (*g)(S)> int min_left(int r) {
        return min_left(r, [](S x) { return g(x); });
    }
    template <class G> int min_left(int r, G g) {
        assert(0 <= r && r <= _n);
        assert(g(e()));
        if (r == 0) return 0;
        r += size;
        for (int i = log; i >= 1; i--) push((r - 1) >> i);
        S sm = e();
        do {
            r--;
            while (r > 1 && (r % 2)) r >>= 1;
            if (!g(op(d[r], sm))) {
                while (r < size) {
                    push(r);
                    r = (2 * r + 1);
                    if (g(op(d[r], sm))) {
                        sm = op(d[r], sm);
                        r--;
                    }
                }
                return r + 1 - size;
            }
            sm = op(d[r], sm);
        } while ((r & -r) != r);
        return 0;
    }

  private:
    int _n, size, log;
    std::vector<S> d;
    std::vector<F> lz;

    void update(int k) { d[k] = op(d[2 * k], d[2 * k + 1]); }
    void all_apply(int k, F f) {
        d[k] = mapping(f, d[k]);
        if (k < size) lz[k] = composition(f, lz[k]);
    }
    void push(int k) {
        all_apply(2 * k, lz[k]);
        all_apply(2 * k + 1, lz[k]);
        lz[k] = id();
    }
};

}  // namespace atcoder


using T1 = int;
using U1 = ll;
array<int,4> temp;
T1 max_id() { return 0; } // T identity
U1 uid() { return 0; } // U identity
T1 max_merg(T1 a, T1 b) { // T1+T2
	return max(a,b);
}
U1 combine(U1 a, U1 b) { // U1 o U2 (U1 most recent op)
	return a+b;
} 
T1 appl(U1 u, T1 t) { // apply U to T
	return t;
}


using T2 = pair<ll, int>;
T2 min_id() {return {1000000000000000000LL, -1};}
T2 min_merg(T2 a, T2 b) {
    return min(a,b);
}
T2 min_appl(U1 u, T2 t) { // apply U to T
    t.first += u;
    return t;
}

















void solve() {
	int n, w_lim; 
    re(n, w_lim);
    //n = 1000000; w_lim = 1000000000;

	vi p(n); 
    re(p); 
    //iota(all(p),1); random_shuffle(all(p));

    reverse(all(p));
    for (int i = 0; i < n; i++) p[i]--;
        
	vi w(n);
    re(w);
    //for (int i = 0; i < n; i++) w[i] = (rand()%w_lim)+1;

	mi ans = 1;

    vector<T1> leaves1(n);
    for (int i = 0; i < n; i++) leaves1[i] = w[p[i]];
	atcoder::lazy_segtree<T1, max_merg, max_id, U1, appl, combine, uid> max_seg(leaves1);

	vi loc(n);
	for (int i = 0; i < n; i++) loc[p[i]] = i;



    vi tree(n+10);
    auto get = [&](int x) {
        int s = 0;
        for (x++; x > 0; x -=x&-x) s += tree[x];
        return s;
    };
    auto add = [&](int x, int d) {
        for (x++; x < n+10; x += x&-x) tree[x] += d;
    };
    for (int i = 0; i < n; i++) add(i, 1);

    vi items(n); iota(all(items), 0);
    sort(all(items), [&](int x, int y) {return w[x] < w[y];});

	for (int i : items) {
		int lidx = max_seg.min_left(loc[i], [&](int x){ return x + w[i] <= w_lim; });
		int ridx = max_seg.max_right(loc[i]+1, [&](int x){ return x + w[i] <= w_lim; });

		int sz = get(ridx-1) - get(lidx-1);
		ans *= sz;
        add(loc[i], -1);
	}




    vector<T2> leaves(n);
    int curmax = 0;
    for (int i = 0; i < n; i++) {
        leaves[i] = {curmax + w[p[i]], i};
        ctmax(curmax, w[p[i]]);
    }
    atcoder::lazy_segtree<T2, min_merg, min_id, U1, min_appl, combine, uid> min_seg(leaves);

    ps(ans);

    set<int> alive;
    for (int kkx = 0; kkx < n; kkx++) {
        while (min_seg.all_prod().first <= w_lim) {
            alive.insert(p[ min_seg.all_prod().second ]);
            min_seg.set(min_seg.all_prod().second, {100000000000000000LL, min_seg.all_prod().second});
        }

        int r = *alive.begin();
        alive.erase(alive.begin());
        pr(r+1, " ");

        int pos = loc[r];
        max_seg.set(pos, 0);

        int cur_max = max_seg.prod(0, pos);
        while (pos < n && cur_max < w[r]) {
            int up_to = max_seg.max_right(pos, [&](int x) {return x <= cur_max;});

            min_seg.apply(pos, min(n,up_to+1), cur_max - w[r]);
            pos = min(n,up_to+1);
            if (up_to < n) cur_max = w[p[up_to]];
        }
    }

	ps();
}


















































	







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

詳細信息

Test #1:

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

input:

5 10
1 2 3 4 5
6 5 3 9 2

output:

3
5 4 2 1 3 

result:

ok 2 lines

Test #2:

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

input:

5 10
1 2 3 4 5
2 4 3 3 8

output:

30
1 5 2 3 4 

result:

ok 2 lines

Test #3:

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

input:

5 10
1 2 3 4 5
2 3 4 5 1

output:

120
1 2 3 4 5 

result:

ok 2 lines

Test #4:

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

input:

5 10
1 2 3 4 5
2 3 4 5 6

output:

60
1 2 3 5 4 

result:

ok 2 lines

Test #5:

score: 0
Accepted
time: 104ms
memory: 19008kb

input:

100000 96
1996 78922 45321 68844 32404 82013 66552 81163 17216 48170 35495 56660 13480 43118 23173 47257 50168 87069 26167 67231 31758 25694 61063 56642 8923 7727 54528 96554 38964 7604 6822 16256 45300 58869 31359 48638 87645 14779 81505 59585 89293 9291 7002 31810 84701 77648 78295 42595 11394 479...

output:

457992974
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 10...

result:

ok 2 lines

Test #6:

score: 0
Accepted
time: 106ms
memory: 14384kb

input:

100000 84
93330 3894 94859 22134 49668 30606 26739 82976 76701 56323 75537 7626 87226 20857 98177 21811 70827 75898 8111 48223 26186 64222 63002 79024 19126 41638 1048 43857 25379 19764 60207 27675 77665 66327 6274 34861 30287 13449 64505 51490 5804 65843 49014 85795 12365 31565 34411 71697 66568 28...

output:

524727018
1723 2800 15421 26278 31659 42502 42606 56945 60694 62369 70160 73990 80586 88502 89122 59690 27661 33622 94788 14089 1146 2690 3632 4491 5439 8588 17476 17922 18136 20123 24857 39523 18825 28520 30999 32947 36013 41413 43842 43919 54502 58104 60783 65767 69064 71878 74728 75343 76546 7807...

result:

ok 2 lines

Test #7:

score: 0
Accepted
time: 115ms
memory: 14504kb

input:

100000 87
300 88662 44078 62834 3753 7407 33249 23452 84415 76976 83633 97611 16701 2788 75559 56876 65161 78422 41095 40238 89019 95291 81242 34629 35820 2766 266 62909 53458 60609 92867 7751 43644 89656 46268 73554 29490 91474 42521 66646 22973 36675 3527 66659 6283 65870 56067 93748 94932 45445 3...

output:

474454223
16291 67920 66350 36657 80297 50836 75962 67504 74275 82684 44748 18794 20817 23451 67820 94633 35098 26272 62387 64130 97543 95388 6171 41925 9995 21720 51796 81891 29780 53247 63390 78398 10287 31830 44454 46864 63394 76771 87042 17437 8412 58246 18774 97383 36854 4632 32575 64180 48940 ...

result:

ok 2 lines

Test #8:

score: 0
Accepted
time: 121ms
memory: 14464kb

input:

100000 100
55629 14377 79945 51098 90204 3853 3177 32017 78776 91382 20382 74435 13483 67713 43513 69929 15961 6388 48752 94868 14114 90543 87776 22290 94148 14665 67822 15542 37889 31214 53405 58817 74349 80153 50913 24099 84889 86056 59976 40327 59231 97231 45030 99883 57171 7168 60283 46638 6697 ...

output:

12361691
68929 26283 16078 8426 80994 89031 90845 85691 11489 83714 218 43955 79942 49055 15944 46958 3923 50718 51881 87716 91070 33513 46064 56932 23620 95805 36252 61014 77254 96568 40681 51389 15855 70350 42900 63333 35239 73615 3271 20950 31494 86984 66093 18145 50335 78044 93515 60899 73400 82...

result:

ok 2 lines

Test #9:

score: 0
Accepted
time: 1509ms
memory: 99516kb

input:

1000000 81
505338 916424 583795 203566 617115 482998 227468 356473 312485 334132 3363 907091 837133 257003 855999 78795 363135 170084 379933 348671 686 989733 970073 613993 760088 594394 96392 386305 559944 490393 934509 798454 875291 431076 978853 472290 445607 906742 260667 85265 928267 662293 850...

output:

1
434417 227927 721379 881382 991471 289735 100004 760754 181792 283705 493486 797104 785634 77915 488388 580313 676447 601952 699628 15819 730688 550717 818459 115930 718996 87059 278519 341770 205766 196170 470043 729232 605060 297713 562576 502884 205091 63073 969512 719434 832742 262524 893809 1...

result:

ok 2 lines

Test #10:

score: 0
Accepted
time: 2007ms
memory: 146724kb

input:

1000000 855853371
671882 962935 236810 309323 731542 936655 349551 915671 728370 235701 940712 512459 431213 624267 374020 458688 149286 146845 938189 496488 78945 50430 630392 695360 119964 195349 284330 320026 415129 675618 454235 401145 366361 129120 527400 159031 540788 688684 238547 914676 4502...

output:

641102369
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 10...

result:

ok 2 lines

Test #11:

score: 0
Accepted
time: 1537ms
memory: 99536kb

input:

1000000 957571370
997755 236289 938217 183949 245742 901546 815337 293623 483897 447597 648079 8259 601800 328449 705646 550681 971772 635040 983132 321434 297617 994716 277334 407243 7535 441861 630008 322245 4749 622934 40122 595912 610078 418322 792502 659098 981324 115306 196723 995928 653988 12...

output:

196613543
8666 50188 54027 60170 63101 84940 100746 141072 144773 162176 166539 180410 188742 200350 233463 289011 294968 327822 361963 362045 365360 373782 378529 384683 395814 400565 412249 426607 451013 453497 486792 500299 501563 503029 527962 532266 540692 549841 554433 555692 578207 587245 309...

result:

ok 2 lines

Test #12:

score: 0
Accepted
time: 1620ms
memory: 99788kb

input:

1000000 808170131
271560 789245 8943 714638 700264 418823 975445 476711 934265 77678 944870 858155 812771 462154 715736 742621 689488 193610 115853 883249 687845 531685 22131 29384 772945 176972 630084 675971 609450 488597 55786 781720 208081 97123 810367 722365 957655 302332 328957 621208 772189 13...

output:

895770364
317901 376287 641310 859340 960574 246282 32177 63684 239374 534359 591735 937287 666444 303601 764716 947219 395979 508421 750441 254676 911202 958056 390533 229585 58162 164836 431844 141305 315803 837011 504379 224738 955205 725934 375706 607486 356819 809721 739670 841619 94497 132028 ...

result:

ok 2 lines

Test #13:

score: 0
Accepted
time: 1621ms
memory: 99712kb

input:

1000000 921697697
510869 325175 912287 76200 267946 196566 280254 478297 605706 422740 294586 757231 806399 421000 946945 826982 892384 94539 164635 669191 29701 283479 197248 916663 922217 873836 641086 135377 885683 938021 917652 415210 386341 909867 104726 417411 584785 221653 310404 785946 50749...

output:

26397744
74052 75686 286379 558067 712866 718029 252642 343310 883971 933200 675850 374677 702925 390886 401806 477880 946457 507454 556609 989214 824674 229271 993468 83455 325821 841962 264526 937152 604811 350821 64736 839110 135921 138196 177501 182090 302505 432962 394141 130562 190620 673567 6...

result:

ok 2 lines

Test #14:

score: 0
Accepted
time: 1642ms
memory: 99788kb

input:

1000000 715224327
142757 848503 196089 967433 276363 163311 39090 467040 906998 624415 676126 894650 38094 559122 446718 948581 878403 60954 92732 411351 351153 714086 588966 236003 874560 356838 655429 454326 560887 554779 336553 360512 278255 146227 122609 258837 216395 166347 171148 428705 503848...

output:

1
725711 716862 11272 806976 86234 607909 475197 584372 220750 864835 838750 461136 764052 271663 669608 748849 409237 373833 186301 795042 393152 944766 681020 322478 634634 83655 132769 255523 171009 76865 331567 528132 604856 695065 448208 571548 792572 672111 366853 662995 271629 290686 208575 6...

result:

ok 2 lines

Test #15:

score: 0
Accepted
time: 1145ms
memory: 100240kb

input:

1000000 94
732832 824385 80610 86380 900983 71723 382380 222054 46533 243003 730000 214251 629211 759027 143920 743196 524310 386215 709124 626379 243508 147769 169616 933797 641552 946395 522265 454896 746806 938530 413949 141576 266714 374723 1495 258 168689 853795 224890 348364 423101 547355 5811...

output:

252663062
690724 825394 618011 650249 818303 780516 332481 422142 541930 407558 699031 214758 536840 93081 21770 691395 456753 679385 367716 146074 339496 267083 728487 615334 820251 927249 839952 270754 978023 753557 637125 194906 288004 57599 382228 165457 5302 51851 266756 856409 96240 396272 772...

result:

ok 2 lines

Test #16:

score: 0
Accepted
time: 1317ms
memory: 123016kb

input:

1000000 99
4178 931168 210242 561422 957522 950349 621494 299138 694428 890073 99566 860399 156939 334289 910642 663741 564875 3797 266989 298372 8263 239639 317861 861704 300698 651181 757530 817042 394445 640956 346401 919687 759026 618445 316528 525462 556450 334906 489721 491750 160475 328418 13...

output:

269552242
2 3 6 10 11 12 15 18 19 20 22 23 27 29 31 33 34 36 38 40 41 44 45 46 48 49 52 57 58 65 67 72 78 80 82 86 89 90 93 95 98 101 102 103 105 107 110 111 114 121 122 123 124 131 132 134 135 137 139 141 143 148 150 151 152 153 154 156 158 161 163 168 171 172 175 176 178 179 180 181 182 184 185 18...

result:

ok 2 lines

Test #17:

score: 0
Accepted
time: 1407ms
memory: 99628kb

input:

1000000 679929501
431235 713814 338483 357970 405842 135564 380661 689063 57872 235545 998283 670897 983715 925773 641244 560970 617441 53369 498534 684410 801204 82176 525998 897028 655245 349349 493440 220184 679407 630370 788841 408291 588088 119206 530508 818552 233973 205211 783475 441990 81557...

output:

90834237
945608 308957 338483 357970 405842 431235 533573 520937 135564 713814 795172 78109 230636 57872 288313 380661 689063 704210 742417 235545 569766 153750 78467 93184 7048 560970 641244 670897 679126 53369 498534 617441 925773 965193 79342 82176 153413 525998 684410 801204 888127 831640 873801...

result:

ok 2 lines

Test #18:

score: 0
Accepted
time: 1685ms
memory: 123352kb

input:

1000000 944684390
431758 595986 647848 934626 598354 501964 160568 865807 884677 189702 952713 354306 594455 802759 2925 255255 786404 831306 765610 462575 874583 940337 346756 349911 600185 567394 308185 139400 353002 134598 220481 946992 401849 16154 228662 4829 321208 819516 189029 907104 858106 ...

output:

413077381
3 5 6 7 9 12 13 15 16 17 18 19 24 25 26 27 33 36 47 48 49 50 51 52 58 59 61 63 64 67 68 69 70 71 72 73 76 77 83 86 90 94 96 97 99 100 101 102 104 107 111 112 113 114 116 118 121 125 128 129 132 134 136 137 139 140 141 144 146 148 150 154 156 159 160 161 164 167 169 170 176 180 181 183 184 ...

result:

ok 2 lines

Test #19:

score: 0
Accepted
time: 1158ms
memory: 99676kb

input:

1000000 93
179362 643184 734387 352388 344737 683812 150908 734803 283731 861889 157277 667401 249449 936820 160643 245780 802361 548408 54020 196140 477358 892136 583310 976438 486205 869087 657774 100483 925805 545771 268088 739613 204989 314998 147901 833469 428883 598222 688822 715899 624252 711...

output:

649477896
743293 690435 806179 511990 66335 717075 672042 466379 437096 310711 708584 445599 845658 139793 108 606294 199490 224868 336249 864261 145793 85502 619896 336270 330976 37172 453848 674426 26285 602579 608503 157048 654945 697812 870059 554588 202907 386285 628924 258521 157543 495310 455...

result:

ok 2 lines

Test #20:

score: 0
Accepted
time: 1217ms
memory: 102272kb

input:

1000000 89
763873 86573 338664 354196 319092 38927 977987 955089 478871 758325 773154 184439 622618 326940 126867 324496 638938 186905 232117 282792 774583 984603 909406 540709 760543 994501 918605 61027 727753 649927 525675 425349 835808 339017 655490 338632 296800 356304 106802 389609 519759 88460...

output:

495453129
9 18 24 33 50 98 108 109 115 123 142 145 160 167 192 202 247 263 265 273 282 284 293 299 317 341 349 369 384 395 397 414 454 468 472 521 535 598 624 635 658 672 675 701 745 785 840 849 865 906 912 929 971 989 1044 1055 1064 1067 1073 1077 1112 1168 1203 1234 1247 1300 1340 1345 1349 1356 1...

result:

ok 2 lines

Test #21:

score: 0
Accepted
time: 1491ms
memory: 99724kb

input:

1000000 954116439
397122 450503 759501 993448 304543 151232 741427 445708 583640 17549 540946 234308 38425 850146 625997 537141 299596 179543 851541 187791 904041 585913 288015 642843 554913 981185 545912 133955 782367 794367 283629 755284 742811 231930 971747 907044 410110 748225 817955 202171 6494...

output:

158902557
742557 95024 192783 336749 610680 627229 557057 599709 704441 720844 784867 939681 331481 352285 996235 234674 350515 551624 686640 691029 298953 524839 752888 759211 900929 617117 61244 592764 824141 632676 508651 762462 69502 573369 771529 935997 35647 363552 641270 667815 746099 156513 ...

result:

ok 2 lines

Test #22:

score: 0
Accepted
time: 1835ms
memory: 102172kb

input:

1000000 835747974
527060 411208 705253 658439 513158 582405 352991 161099 538587 243319 241504 94970 152928 682292 118342 377276 764212 93502 132399 994592 724092 141564 870994 931053 798419 777558 872180 830832 312291 394281 686471 865266 380480 14195 973089 544150 287133 12334 72439 555268 297243 ...

output:

838527552
16 31 38 42 65 71 81 140 145 159 160 174 242 395 400 401 404 419 421 449 483 523 534 537 553 593 599 651 654 663 676 685 701 716 741 753 778 779 787 789 796 817 841 852 854 871 891 898 899 909 915 945 953 962 968 1044 1063 1079 1105 1107 1118 1154 1192 1208 1243 1265 1274 1286 1315 1318 13...

result:

ok 2 lines

Test #23:

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

input:

8 10
1 7 6 4 3 8 5 2
2 7 3 1 3 7 5 7

output:

1680
1 2 3 4 5 8 6 7 

result:

ok 2 lines

Test #24:

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

input:

8 10
3 6 5 2 1 7 4 8
6 9 7 10 1 6 4 2

output:

12
8 4 1 5 7 2 6 3 

result:

ok 2 lines

Extra Test:

score: 0
Extra Test Passed