QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#842611#9967. Imbalanced Teamsucup-team987#AC ✓1ms3908kbC++2316.3kb2025-01-04 13:40:052025-01-04 13:40:08

Judging History

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

  • [2025-01-04 13:40:08]
  • 评测
  • 测评结果:AC
  • 用时:1ms
  • 内存:3908kb
  • [2025-01-04 13:40:05]
  • 提交

answer

/**
 * date   : 2025-01-04 14:39:53
 * author : Nyaan
 */

#define NDEBUG

using namespace std;

// intrinstic
#include <immintrin.h>

#include <algorithm>
#include <array>
#include <bitset>
#include <cassert>
#include <cctype>
#include <cfenv>
#include <cfloat>
#include <chrono>
#include <cinttypes>
#include <climits>
#include <cmath>
#include <complex>
#include <cstdarg>
#include <cstddef>
#include <cstdint>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <deque>
#include <fstream>
#include <functional>
#include <initializer_list>
#include <iomanip>
#include <ios>
#include <iostream>
#include <istream>
#include <iterator>
#include <limits>
#include <list>
#include <map>
#include <memory>
#include <new>
#include <numeric>
#include <ostream>
#include <queue>
#include <random>
#include <set>
#include <sstream>
#include <stack>
#include <streambuf>
#include <string>
#include <tr2/dynamic_bitset>
#include <tuple>
#include <type_traits>
#include <typeinfo>
#include <unordered_map>
#include <unordered_set>
#include <utility>
#include <vector>

// utility

namespace Nyaan {
using ll = long long;
using i64 = long long;
using u64 = unsigned long long;
using i128 = __int128_t;
using u128 = __uint128_t;

template <typename T>
using V = vector<T>;
template <typename T>
using VV = vector<vector<T>>;
using vi = vector<int>;
using vl = vector<long long>;
using vd = V<double>;
using vs = V<string>;
using vvi = vector<vector<int>>;
using vvl = vector<vector<long long>>;
template <typename T>
using minpq = priority_queue<T, vector<T>, greater<T>>;

template <typename T, typename U>
struct P : pair<T, U> {
  template <typename... Args>
  constexpr P(Args... args) : pair<T, U>(args...) {}

  using pair<T, U>::first;
  using pair<T, U>::second;

  P &operator+=(const P &r) {
    first += r.first;
    second += r.second;
    return *this;
  }
  P &operator-=(const P &r) {
    first -= r.first;
    second -= r.second;
    return *this;
  }
  P &operator*=(const P &r) {
    first *= r.first;
    second *= r.second;
    return *this;
  }
  template <typename S>
  P &operator*=(const S &r) {
    first *= r, second *= r;
    return *this;
  }
  P operator+(const P &r) const { return P(*this) += r; }
  P operator-(const P &r) const { return P(*this) -= r; }
  P operator*(const P &r) const { return P(*this) *= r; }
  template <typename S>
  P operator*(const S &r) const {
    return P(*this) *= r;
  }
  P operator-() const { return P{-first, -second}; }
};

using pl = P<ll, ll>;
using pi = P<int, int>;
using vp = V<pl>;

constexpr int inf = 1001001001;
constexpr long long infLL = 4004004004004004004LL;

template <typename T>
int sz(const T &t) {
  return t.size();
}

template <typename T, typename U>
inline bool amin(T &x, U y) {
  return (y < x) ? (x = y, true) : false;
}
template <typename T, typename U>
inline bool amax(T &x, U y) {
  return (x < y) ? (x = y, true) : false;
}

template <typename T>
inline T Max(const vector<T> &v) {
  return *max_element(begin(v), end(v));
}
template <typename T>
inline T Min(const vector<T> &v) {
  return *min_element(begin(v), end(v));
}
template <typename T>
inline long long Sum(const vector<T> &v) {
  return accumulate(begin(v), end(v), 0LL);
}

template <typename T>
int lb(const vector<T> &v, const T &a) {
  return lower_bound(begin(v), end(v), a) - begin(v);
}
template <typename T>
int ub(const vector<T> &v, const T &a) {
  return upper_bound(begin(v), end(v), a) - begin(v);
}

constexpr long long TEN(int n) {
  long long ret = 1, x = 10;
  for (; n; x *= x, n >>= 1) ret *= (n & 1 ? x : 1);
  return ret;
}

template <typename T, typename U>
pair<T, U> mkp(const T &t, const U &u) {
  return make_pair(t, u);
}

template <typename T>
vector<T> mkrui(const vector<T> &v, bool rev = false) {
  vector<T> ret(v.size() + 1);
  if (rev) {
    for (int i = int(v.size()) - 1; i >= 0; i--) ret[i] = v[i] + ret[i + 1];
  } else {
    for (int i = 0; i < int(v.size()); i++) ret[i + 1] = ret[i] + v[i];
  }
  return ret;
};

template <typename T>
vector<T> mkuni(const vector<T> &v) {
  vector<T> ret(v);
  sort(ret.begin(), ret.end());
  ret.erase(unique(ret.begin(), ret.end()), ret.end());
  return ret;
}

template <typename F>
vector<int> mkord(int N, F f) {
  vector<int> ord(N);
  iota(begin(ord), end(ord), 0);
  sort(begin(ord), end(ord), f);
  return ord;
}

template <typename T>
vector<int> mkinv(vector<T> &v) {
  int max_val = *max_element(begin(v), end(v));
  vector<int> inv(max_val + 1, -1);
  for (int i = 0; i < (int)v.size(); i++) inv[v[i]] = i;
  return inv;
}

vector<int> mkiota(int n) {
  vector<int> ret(n);
  iota(begin(ret), end(ret), 0);
  return ret;
}

template <typename T>
T mkrev(const T &v) {
  T w{v};
  reverse(begin(w), end(w));
  return w;
}

template <typename T>
bool nxp(T &v) {
  return next_permutation(begin(v), end(v));
}

// 返り値の型は入力の T に依存
// i 要素目 : [0, a[i])
template <typename T>
vector<vector<T>> product(const vector<T> &a) {
  vector<vector<T>> ret;
  vector<T> v;
  auto dfs = [&](auto rc, int i) -> void {
    if (i == (int)a.size()) {
      ret.push_back(v);
      return;
    }
    for (int j = 0; j < a[i]; j++) v.push_back(j), rc(rc, i + 1), v.pop_back();
  };
  dfs(dfs, 0);
  return ret;
}

// F : function(void(T&)), mod を取る操作
// T : 整数型のときはオーバーフローに注意する
template <typename T>
T Power(T a, long long n, const T &I, const function<void(T &)> &f) {
  T res = I;
  for (; n; f(a = a * a), n >>= 1) {
    if (n & 1) f(res = res * a);
  }
  return res;
}
// T : 整数型のときはオーバーフローに注意する
template <typename T>
T Power(T a, long long n, const T &I = T{1}) {
  return Power(a, n, I, function<void(T &)>{[](T &) -> void {}});
}

template <typename T>
T Rev(const T &v) {
  T res = v;
  reverse(begin(res), end(res));
  return res;
}

template <typename T>
vector<T> Transpose(const vector<T> &v) {
  using U = typename T::value_type;
  if(v.empty()) return {};
  int H = v.size(), W = v[0].size();
  vector res(W, T(H, U{}));
  for (int i = 0; i < H; i++) {
    for (int j = 0; j < W; j++) {
      res[j][i] = v[i][j];
    }
  }
  return res;
}

template <typename T>
vector<T> Rotate(const vector<T> &v, int clockwise = true) {
  using U = typename T::value_type;
  int H = v.size(), W = v[0].size();
  vector res(W, T(H, U{}));
  for (int i = 0; i < H; i++) {
    for (int j = 0; j < W; j++) {
      if (clockwise) {
        res[W - 1 - j][i] = v[i][j];
      } else {
        res[j][H - 1 - i] = v[i][j];
      }
    }
  }
  return res;
}

}  // namespace Nyaan


// bit operation

namespace Nyaan {
__attribute__((target("popcnt"))) inline int popcnt(const u64 &a) {
  return __builtin_popcountll(a);
}
inline int lsb(const u64 &a) { return a ? __builtin_ctzll(a) : 64; }
inline int ctz(const u64 &a) { return a ? __builtin_ctzll(a) : 64; }
inline int msb(const u64 &a) { return a ? 63 - __builtin_clzll(a) : -1; }
template <typename T>
inline int gbit(const T &a, int i) {
  return (a >> i) & 1;
}
template <typename T>
inline void sbit(T &a, int i, bool b) {
  if (gbit(a, i) != b) a ^= T(1) << i;
}
constexpr long long PW(int n) { return 1LL << n; }
constexpr long long MSK(int n) { return (1LL << n) - 1; }
}  // namespace Nyaan


// inout

namespace Nyaan {

template <typename T, typename U>
ostream &operator<<(ostream &os, const pair<T, U> &p) {
  os << p.first << " " << p.second;
  return os;
}
template <typename T, typename U>
istream &operator>>(istream &is, pair<T, U> &p) {
  is >> p.first >> p.second;
  return is;
}

template <typename T>
ostream &operator<<(ostream &os, const vector<T> &v) {
  int s = (int)v.size();
  for (int i = 0; i < s; i++) os << (i ? " " : "") << v[i];
  return os;
}
template <typename T>
istream &operator>>(istream &is, vector<T> &v) {
  for (auto &x : v) is >> x;
  return is;
}

istream &operator>>(istream &is, __int128_t &x) {
  string S;
  is >> S;
  x = 0;
  int flag = 0;
  for (auto &c : S) {
    if (c == '-') {
      flag = true;
      continue;
    }
    x *= 10;
    x += c - '0';
  }
  if (flag) x = -x;
  return is;
}

istream &operator>>(istream &is, __uint128_t &x) {
  string S;
  is >> S;
  x = 0;
  for (auto &c : S) {
    x *= 10;
    x += c - '0';
  }
  return is;
}

ostream &operator<<(ostream &os, __int128_t x) {
  if (x == 0) return os << 0;
  if (x < 0) os << '-', x = -x;
  string S;
  while (x) S.push_back('0' + x % 10), x /= 10;
  reverse(begin(S), end(S));
  return os << S;
}
ostream &operator<<(ostream &os, __uint128_t x) {
  if (x == 0) return os << 0;
  string S;
  while (x) S.push_back('0' + x % 10), x /= 10;
  reverse(begin(S), end(S));
  return os << S;
}

void in() {}
template <typename T, class... U>
void in(T &t, U &...u) {
  cin >> t;
  in(u...);
}

void out() { cout << "\n"; }
template <typename T, class... U, char sep = ' '>
void out(const T &t, const U &...u) {
  cout << t;
  if (sizeof...(u)) cout << sep;
  out(u...);
}

struct IoSetupNya {
  IoSetupNya() {
    cin.tie(nullptr);
    ios::sync_with_stdio(false);
    cout << fixed << setprecision(15);
    cerr << fixed << setprecision(7);
  }
} iosetupnya;

}  // namespace Nyaan


// debug


#ifdef NyaanDebug
#define trc(...) (void(0))
#else
#define trc(...) (void(0))
#endif

#ifdef NyaanLocal
#define trc2(...) (void(0))
#else
#define trc2(...) (void(0))
#endif


// macro

#define each(x, v) for (auto&& x : v)
#define each2(x, y, v) for (auto&& [x, y] : v)
#define all(v) (v).begin(), (v).end()
#define rep(i, N) for (long long i = 0; i < (long long)(N); i++)
#define repr(i, N) for (long long i = (long long)(N)-1; i >= 0; i--)
#define rep1(i, N) for (long long i = 1; i <= (long long)(N); i++)
#define repr1(i, N) for (long long i = (N); (long long)(i) > 0; i--)
#define reg(i, a, b) for (long long i = (a); i < (b); i++)
#define regr(i, a, b) for (long long i = (b)-1; i >= (a); i--)
#define fi first
#define se second
#define ini(...)   \
  int __VA_ARGS__; \
  in(__VA_ARGS__)
#define inl(...)         \
  long long __VA_ARGS__; \
  in(__VA_ARGS__)
#define ins(...)      \
  string __VA_ARGS__; \
  in(__VA_ARGS__)
#define in2(s, t)                           \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i]);                         \
  }
#define in3(s, t, u)                        \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i], u[i]);                   \
  }
#define in4(s, t, u, v)                     \
  for (int i = 0; i < (int)s.size(); i++) { \
    in(s[i], t[i], u[i], v[i]);             \
  }
#define die(...)             \
  do {                       \
    Nyaan::out(__VA_ARGS__); \
    return;                  \
  } while (0)


namespace Nyaan {
void solve();
}
int main() { Nyaan::solve(); }


//


template <uint32_t mod>
struct LazyMontgomeryModInt {
  using mint = LazyMontgomeryModInt;
  using i32 = int32_t;
  using u32 = uint32_t;
  using u64 = uint64_t;

  static constexpr u32 get_r() {
    u32 ret = mod;
    for (i32 i = 0; i < 4; ++i) ret *= 2 - mod * ret;
    return ret;
  }

  static constexpr u32 r = get_r();
  static constexpr u32 n2 = -u64(mod) % mod;
  static_assert(mod < (1 << 30), "invalid, mod >= 2 ^ 30");
  static_assert((mod & 1) == 1, "invalid, mod % 2 == 0");
  static_assert(r * mod == 1, "this code has bugs.");

  u32 a;

  constexpr LazyMontgomeryModInt() : a(0) {}
  constexpr LazyMontgomeryModInt(const int64_t &b)
      : a(reduce(u64(b % mod + mod) * n2)){};

  static constexpr u32 reduce(const u64 &b) {
    return (b + u64(u32(b) * u32(-r)) * mod) >> 32;
  }

  constexpr mint &operator+=(const mint &b) {
    if (i32(a += b.a - 2 * mod) < 0) a += 2 * mod;
    return *this;
  }

  constexpr mint &operator-=(const mint &b) {
    if (i32(a -= b.a) < 0) a += 2 * mod;
    return *this;
  }

  constexpr mint &operator*=(const mint &b) {
    a = reduce(u64(a) * b.a);
    return *this;
  }

  constexpr mint &operator/=(const mint &b) {
    *this *= b.inverse();
    return *this;
  }

  constexpr mint operator+(const mint &b) const { return mint(*this) += b; }
  constexpr mint operator-(const mint &b) const { return mint(*this) -= b; }
  constexpr mint operator*(const mint &b) const { return mint(*this) *= b; }
  constexpr mint operator/(const mint &b) const { return mint(*this) /= b; }
  constexpr bool operator==(const mint &b) const {
    return (a >= mod ? a - mod : a) == (b.a >= mod ? b.a - mod : b.a);
  }
  constexpr bool operator!=(const mint &b) const {
    return (a >= mod ? a - mod : a) != (b.a >= mod ? b.a - mod : b.a);
  }
  constexpr mint operator-() const { return mint() - mint(*this); }
  constexpr mint operator+() const { return mint(*this); }

  constexpr mint pow(u64 n) const {
    mint ret(1), mul(*this);
    while (n > 0) {
      if (n & 1) ret *= mul;
      mul *= mul;
      n >>= 1;
    }
    return ret;
  }

  constexpr mint inverse() const {
    int x = get(), y = mod, u = 1, v = 0, t = 0, tmp = 0;
    while (y > 0) {
      t = x / y;
      x -= t * y, u -= t * v;
      tmp = x, x = y, y = tmp;
      tmp = u, u = v, v = tmp;
    }
    return mint{u};
  }

  friend ostream &operator<<(ostream &os, const mint &b) {
    return os << b.get();
  }

  friend istream &operator>>(istream &is, mint &b) {
    int64_t t;
    is >> t;
    b = LazyMontgomeryModInt<mod>(t);
    return (is);
  }

  constexpr u32 get() const {
    u32 ret = reduce(a);
    return ret >= mod ? ret - mod : ret;
  }

  static constexpr u32 get_mod() { return mod; }
};





using namespace std;

// コンストラクタの MAX に 「C(n, r) や fac(n) でクエリを投げる最大の n 」
// を入れると倍速くらいになる
// mod を超えて前計算して 0 割りを踏むバグは対策済み
template <typename T>
struct Binomial {
  vector<T> f, g, h;
  Binomial(int MAX = 0) {
    assert(T::get_mod() != 0 && "Binomial<mint>()");
    f.resize(1, T{1});
    g.resize(1, T{1});
    h.resize(1, T{1});
    if (MAX > 0) extend(MAX + 1);
  }

  void extend(int m = -1) {
    int n = f.size();
    if (m == -1) m = n * 2;
    m = min<int>(m, T::get_mod());
    if (n >= m) return;
    f.resize(m);
    g.resize(m);
    h.resize(m);
    for (int i = n; i < m; i++) f[i] = f[i - 1] * T(i);
    g[m - 1] = f[m - 1].inverse();
    h[m - 1] = g[m - 1] * f[m - 2];
    for (int i = m - 2; i >= n; i--) {
      g[i] = g[i + 1] * T(i + 1);
      h[i] = g[i] * f[i - 1];
    }
  }

  T fac(int i) {
    if (i < 0) return T(0);
    while (i >= (int)f.size()) extend();
    return f[i];
  }

  T finv(int i) {
    if (i < 0) return T(0);
    while (i >= (int)g.size()) extend();
    return g[i];
  }

  T inv(int i) {
    if (i < 0) return -inv(-i);
    while (i >= (int)h.size()) extend();
    return h[i];
  }

  T C(int n, int r) {
    if (n < 0 || n < r || r < 0) return T(0);
    return fac(n) * finv(n - r) * finv(r);
  }

  inline T operator()(int n, int r) { return C(n, r); }

  template <typename I>
  T multinomial(const vector<I>& r) {
    static_assert(is_integral<I>::value == true);
    int n = 0;
    for (auto& x : r) {
      if (x < 0) return T(0);
      n += x;
    }
    T res = fac(n);
    for (auto& x : r) res *= finv(x);
    return res;
  }

  template <typename I>
  T operator()(const vector<I>& r) {
    return multinomial(r);
  }

  T C_naive(int n, int r) {
    if (n < 0 || n < r || r < 0) return T(0);
    T ret = T(1);
    r = min(r, n - r);
    for (int i = 1; i <= r; ++i) ret *= inv(i) * (n--);
    return ret;
  }

  T P(int n, int r) {
    if (n < 0 || n < r || r < 0) return T(0);
    return fac(n) * finv(n - r);
  }

  // [x^r] 1 / (1-x)^n
  T H(long long n, long long r) {
    if (n < 0 || r < 0) return T(0);
    return r == 0 ? 1 : C(n + r - 1, r);
  }
};


//
using namespace Nyaan;
using mint = LazyMontgomeryModInt<1000000007>;
using vm = vector<mint>;
using vvm = vector<vm>;
Binomial<mint> C;

using namespace Nyaan;

void q() {
  inl(N, K);
  vl a(N);
  in(a);
  sort(all(a));

  ll s = 0;
  rep(i, K) s -= a[i];
  rep(i, K) s += a[N - 1 - i];

  map<int, int> mp;
  each(x, a) mp[x]++;

  int l = K - 1;
  while (l != 0 and a[l - 1] == a[K - 1]) l--;
  int r = N - K;
  while (r + 1 != N and a[N - K] == a[r + 1]) r++;
  int lnum = (K - 1) - l + 1;
  int rnum = r - (N - K) + 1;

  int lval = a[K - 1];
  int rval = a[N - K];

  trc(l, lnum, lval);
  trc(r, rnum, rval);

  if (a[0] == a[N - 1]) {
    out(s, C(vl{lnum, rnum, mp[lval] - lnum - rnum}) / 2);
  } else if (lval == rval) {
    out(s, C(vl{lnum, rnum, mp[lval] - lnum - rnum}));
  } else {
    out(s, C(mp[lval], lnum) * C(mp[rval], rnum));
  }
}

void Nyaan::solve() {
  int t = 1;
  // in(t);
  while (t--) q();
}

詳細信息

Test #1:

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

input:

6 2
2 5 7 2 5 2

output:

8 6

result:

ok 2 number(s): "8 6"

Test #2:

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

input:

5 2
1 1 1 1 1

output:

0 15

result:

ok 2 number(s): "0 15"

Test #3:

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

input:

2 1
1 1

output:

0 1

result:

ok 2 number(s): "0 1"

Test #4:

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

input:

2 1
1 2

output:

1 1

result:

ok 2 number(s): "1 1"

Test #5:

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

input:

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

output:

12 1

result:

ok 2 number(s): "12 1"

Test #6:

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

input:

14 3
57 57 57 57 57 57 57 57 57 57 57 57 57 57

output:

0 30030

result:

ok 2 number(s): "0 30030"

Test #7:

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

input:

13 5
858336 900782 858336 900782 900782 858336 900782 858336 858336 858336 858336 858336 52093

output:

976027 280

result:

ok 2 number(s): "976027 280"

Test #8:

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

input:

14 4
447923 447923 447923 211106 447923 447923 447923 447923 16966 447923 211106 515550 211106 211106

output:

1209035 224

result:

ok 2 number(s): "1209035 224"

Test #9:

score: 0
Accepted
time: 1ms
memory: 3740kb

input:

2000 935
57596 988638 30477 956599 52986 460052 987863 291984 947848 109335 541003 338365 939256 297365 926486 944912 700042 810595 412192 37130 343207 311311 681629 48155 319677 435667 731251 919378 254216 893282 661237 740159 787502 501360 517533 349880 565298 536545 192793 18666 425164 856977 536...

output:

493241703 1

result:

ok 2 number(s): "493241703 1"

Test #10:

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

input:

2000 1000
101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101493 101...

output:

0 36237869

result:

ok 2 number(s): "0 36237869"

Test #11:

score: 0
Accepted
time: 1ms
memory: 3720kb

input:

2000 1000
834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834985 834...

output:

95671357 1001

result:

ok 2 number(s): "95671357 1001"

Test #12:

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

input:

2000 1000
999763 998795 997229 996607 995585 995585 995080 995080 995080 994251 994251 994251 994169 994158 994051 993410 993410 993410 993410 993410 993410 993410 993410 992448 992314 992176 990170 989664 989638 987205 987205 987205 987205 987205 987205 987067 986997 986233 985924 985707 985180 985...

output:

85351652 417058531

result:

ok 2 number(s): "85351652 417058531"

Test #13:

score: 0
Accepted
time: 1ms
memory: 3600kb

input:

2000 1000
220336 697950 570674 245907 697950 409648 697950 245907 697950 245907 245907 245907 496369 697950 697950 697950 245907 435446 697950 245907 697950 245907 697950 317643 245907 245907 697950 697950 697950 245907 697950 697950 697950 697950 697950 220336 412219 697950 245907 245907 697950 697...

output:

406826343 1001

result:

ok 2 number(s): "406826343 1001"

Test #14:

score: 0
Accepted
time: 1ms
memory: 3640kb

input:

2000 1000
824739 824739 511894 511894 511894 824739 824739 511894 511894 511894 511894 511894 824739 511894 422607 824739 824739 824739 511894 824739 824739 824739 824739 824739 511894 824739 824739 824739 824739 824739 824739 511894 511894 824739 511894 824739 511894 824739 511894 824739 511894 824...

output:

312778791 2

result:

ok 2 number(s): "312778791 2"

Test #15:

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

input:

2000 1000
963877 389725 389725 389725 278964 278964 389725 963877 278964 234531 389725 278964 963877 963877 234531 963877 389725 963877 963877 278964 123625 234531 278964 389725 389725 963877 963877 389725 389725 278964 123625 389725 389725 963877 963877 389725 278964 963877 278964 234531 278964 389...

output:

402934678 571

result:

ok 2 number(s): "402934678 571"

Test #16:

score: 0
Accepted
time: 1ms
memory: 3728kb

input:

2000 1000
810623 810623 215961 213971 72125 810623 810623 810623 456356 376932 739377 810623 810623 810623 810623 724747 810623 810623 810623 445139 417445 487074 810623 810623 115166 810623 810623 810623 810623 156975 682791 810623 810623 502268 810623 810623 148063 697295 810623 617315 187980 8106...

output:

336729651 864576772

result:

ok 2 number(s): "336729651 864576772"

Test #17:

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

input:

2000 1000
15252 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 138241 1382...

output:

530383255 379

result:

ok 2 number(s): "530383255 379"

Test #18:

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

input:

2000 1000
68512 68512 68512 68512 68512 68512 68512 68512 68512 68512 415790 68512 415790 68512 68512 68512 415790 68512 584278 68512 415790 68512 68512 68512 68512 352649 68512 68512 68512 68512 68512 68512 68512 68512 68512 68512 68512 68512 68512 15848 68512 415790 415790 68512 68512 68512 68512 ...

output:

197366653 946019815

result:

ok 2 number(s): "197366653 946019815"

Test #19:

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

input:

1996 35
231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 231100 23110...

output:

0 732363067

result:

ok 2 number(s): "0 732363067"

Test #20:

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

input:

1996 693
129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 129742 1297...

output:

310512311 144403077

result:

ok 2 number(s): "310512311 144403077"

Test #21:

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

input:

1995 100
502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 502532 5025...

output:

6099485 530384736

result:

ok 2 number(s): "6099485 530384736"

Test #22:

score: 0
Accepted
time: 1ms
memory: 3620kb

input:

2000 702
689650 689650 689650 689650 689650 257789 689650 257789 689650 689650 689650 649096 689650 689650 64913 649096 257789 689650 689650 689650 479477 537847 689650 689650 689650 689650 689650 689650 257789 689650 689650 689650 689650 689650 649096 689650 689650 257789 689650 257789 649096 25778...

output:

167362101 606588929

result:

ok 2 number(s): "167362101 606588929"

Test #23:

score: 0
Accepted
time: 1ms
memory: 3680kb

input:

2000 511
434117 434117 167194 167194 167194 320034 167194 138620 57474 57474 434117 167194 167194 167194 167194 57474 57474 434117 167194 167194 57474 167194 57474 57474 57474 434117 167194 434117 167194 57474 57474 57474 434117 434117 167194 434117 167194 167194 167194 57474 167194 434117 209273 16...

output:

211514717 959420

result:

ok 2 number(s): "211514717 959420"

Test #24:

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

input:

1999 244
336742 336742 336742 163948 336742 336742 163948 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 163948 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 336742 3367...

output:

52218989 449117049

result:

ok 2 number(s): "52218989 449117049"

Test #25:

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

input:

2000 901
41873 329018 329018 2744 329018 329018 329018 329018 2744 329018 41873 228136 269177 2744 329018 329018 329018 329018 75126 329018 15348 329018 329018 329018 329018 329018 329018 329018 238309 329018 92708 329018 329018 308134 329018 124989 329018 329018 329018 104062 329018 329018 329018 3...

output:

116724056 279087270

result:

ok 2 number(s): "116724056 279087270"

Test #26:

score: 0
Accepted
time: 1ms
memory: 3888kb

input:

1996 1
10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037 10037...

output:

0 1991010

result:

ok 2 number(s): "0 1991010"

Test #27:

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

input:

1999 206
655647 655647 655647 655647 696220 655647 655647 655647 655647 655647 655647 655647 696220 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 655647 696220 655647 655647 655647 655647 655647 655647 655647 696220 655647 655647 655647 6556...

output:

13077003 122255271

result:

ok 2 number(s): "13077003 122255271"

Test #28:

score: 0
Accepted
time: 1ms
memory: 3908kb

input:

1993 541
612935 636811 644833 645310 612935 648500 631295 644535 633495 612935 612935 612935 612935 612935 648500 648500 645324 612935 648500 612935 612935 648500 612935 612935 612935 612935 612935 612935 648500 622150 627296 612935 629349 648500 612935 625984 612935 612935 648500 612935 648500 6129...

output:

19240665 608611794

result:

ok 2 number(s): "19240665 608611794"

Test #29:

score: 0
Accepted
time: 1ms
memory: 3904kb

input:

2000 221
241380 241380 374457 241380 241380 241380 696478 696478 241380 241380 409314 483710 696478 696478 696478 696478 696478 696478 241380 241380 872000 241380 696478 291014 782435 241380 241380 803240 696478 241380 241380 241380 696478 696478 696478 696478 241380 696478 241380 844283 241380 2413...

output:

131361754 473559136

result:

ok 2 number(s): "131361754 473559136"

Test #30:

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

input:

1993 343
555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 555330 5553...

output:

54777558 519900873

result:

ok 2 number(s): "54777558 519900873"

Test #31:

score: 0
Accepted
time: 1ms
memory: 3852kb

input:

2000 186
700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 700789 7007...

output:

87151818 928211245

result:

ok 2 number(s): "87151818 928211245"

Test #32:

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

input:

1993 700
623894 623894 475133 860406 203186 623894 774169 774169 774169 475133 623894 774169 748033 203186 475133 623894 748033 623894 475133 774169 774169 774169 475133 623894 623894 203186 623894 203186 623894 475133 718749 774169 623894 623894 774169 203186 774169 203186 774169 748033 475133 7480...

output:

287280090 53244

result:

ok 2 number(s): "287280090 53244"

Test #33:

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

input:

1995 728
779764 848766 734106 779764 763683 779764 665277 285893 779764 875055 304657 285893 779764 779764 285893 779764 779764 779764 779764 779764 779764 779764 779764 285893 285893 285893 665277 665277 779764 779764 285893 831705 285893 704495 779764 285893 779764 285893 285893 779764 779764 2858...

output:

371726887 775274252

result:

ok 2 number(s): "371726887 775274252"

Test #34:

score: 0
Accepted
time: 1ms
memory: 3624kb

input:

1997 927
572674 572674 280099 572674 36250 122992 572674 191914 8661 217131 572674 572674 572674 572674 419716 572674 572674 572674 572674 572674 217131 572674 572674 572674 166486 572674 419716 572674 382507 419716 419716 572674 572674 572674 280099 379194 157092 572674 572674 280099 177228 163710 ...

output:

286636084 843948387

result:

ok 2 number(s): "286636084 843948387"

Test #35:

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

input:

1993 481
999693 999693 999693 999693 999693 998210 996510 995423 995089 992358 992245 992108 992108 992108 991703 991093 990890 990644 987894 987134 986842 986604 985668 982039 981525 980612 980210 977300 975707 974624 973748 971733 969680 969653 968686 968317 967738 966197 965257 965257 965257 9637...

output:

298749808 869915276

result:

ok 2 number(s): "298749808 869915276"

Test #36:

score: 0
Accepted
time: 1ms
memory: 3552kb

input:

2000 630
952180 748007 219118 456547 952180 952180 767878 952180 767878 575470 285503 952180 748007 952180 952180 952180 575470 952180 575470 952180 952180 767878 743577 748007 952180 720943 575470 720943 952180 575470 952180 720943 720943 767878 952180 575470 743577 952180 456547 720943 720943 7512...

output:

227697048 401900157

result:

ok 2 number(s): "227697048 401900157"

Test #37:

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

input:

2000 393
890592 766981 890592 766981 766981 766981 895851 890592 895851 895851 890592 895851 895851 895851 890592 895851 890592 766981 895851 895851 890592 895851 895851 890592 890592 766981 895851 890592 895851 890592 895851 890592 890592 895851 890592 890592 766981 766981 895851 890592 895851 8905...

output:

50645910 693975258

result:

ok 2 number(s): "50645910 693975258"

Test #38:

score: 0
Accepted
time: 1ms
memory: 3876kb

input:

2000 457
563252 559847 574717 786906 559642 567124 567124 559642 565972 567124 564102 564102 565972 559642 566763 567124 559642 786906 786906 563484 567068 565585 786906 567124 566346 786906 559642 574562 563771 570825 561969 567124 559642 561584 565299 786906 559642 567124 569807 786906 567124 5596...

output:

103647459 42

result:

ok 2 number(s): "103647459 42"

Test #39:

score: 0
Accepted
time: 1ms
memory: 3556kb

input:

1993 656
67937 615218 615218 615218 67937 615218 67937 615218 615218 67937 615218 615218 67937 67937 67937 67937 67937 67937 615218 615218 615218 67937 615218 67937 615218 67937 615218 67937 615218 615218 615218 615218 995043 615218 67937 615218 615218 800075 615218 615218 615218 615218 615218 61996...

output:

391629438 462660524

result:

ok 2 number(s): "391629438 462660524"

Test #40:

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

input:

1997 672
384143 384143 384143 243847 82873 22254 384143 384143 50289 384143 384143 203333 22254 384143 22254 70690 384143 22254 22254 15572 384143 214927 384143 384143 384143 22254 384143 384143 243847 22254 243847 384143 384143 243847 231381 384143 22254 384143 384143 384143 384143 384143 384143 38...

output:

192781988 95854834

result:

ok 2 number(s): "192781988 95854834"

Test #41:

score: 0
Accepted
time: 1ms
memory: 3880kb

input:

2000 130
209374 209374 209374 209374 86362 582751 582751 209374 209374 209374 86362 86362 86362 86362 209374 209374 209374 209374 209374 209374 582751 209374 86362 86362 86362 582751 86362 209374 209374 86362 86362 209374 582751 209374 86362 209374 86362 209374 86362 86362 86362 209374 86362 209374 ...

output:

76833050 758641

result:

ok 2 number(s): "76833050 758641"

Test #42:

score: 0
Accepted
time: 1ms
memory: 3608kb

input:

2000 599
228240 228240 228240 923209 228240 228240 228240 683802 683802 923209 933811 228240 228240 725189 228240 50313 923209 683802 923209 228240 220967 228240 100049 228240 923209 228240 923209 35821 228240 100049 923209 228240 683802 228240 100049 767142 923209 100049 228240 228240 923209 923209...

output:

464181375 520932862

result:

ok 2 number(s): "464181375 520932862"

Test #43:

score: 0
Accepted
time: 1ms
memory: 3884kb

input:

2000 277
625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 625218 6252...

output:

108979111 667720737

result:

ok 2 number(s): "108979111 667720737"

Test #44:

score: 0
Accepted
time: 1ms
memory: 3816kb

input:

2000 867
996789 996789 996789 996789 996789 975515 975515 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 916091 9160...

output:

589665604 58726973

result:

ok 2 number(s): "589665604 58726973"

Test #45:

score: 0
Accepted
time: 1ms
memory: 3592kb

input:

2000 689
572959 238918 130497 610749 682013 130497 130497 508058 190574 238918 4212 567691 130497 190574 508058 699431 238918 729711 130497 572959 130497 190574 885298 130497 834864 115509 130497 572959 148961 130497 737395 130497 190574 190574 572959 130497 190574 543101 875404 737395 130497 572959...

output:

383970121 87447683

result:

ok 2 number(s): "383970121 87447683"

Test #46:

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

input:

2000 1000
403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 403945 816114 816114 816114 816114 816114 816114 816114 883810 911598 911598 911598 911598 972174 972174 972174 972174 972174 972174 972...

output:

19500102 1

result:

ok 2 number(s): "19500102 1"

Test #47:

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

input:

2000 1
1000000 1 1000000 1 1 1 1 1 1 1 1 1 1 1 1000000 1 1 1000000 1 1 1 1 1000000 1 1000000 1000000 1000000 1000000 1 1 1000000 1000000 1 1000000 1000000 1000000 1000000 1000000 1000000 1 1000000 1 1 1 1 1 1 1000000 1 1 1000000 1000000 1 1000000 1 1 1000000 1000000 1 1000000 1 1 1000000 1 1000000 1...

output:

999999 1000000

result:

ok 2 number(s): "999999 1000000"

Test #48:

score: 0
Accepted
time: 1ms
memory: 3612kb

input:

2000 57
1 1 1 1000000 1000000 1000000 1000000 1 1 1000000 1000000 1 1000000 1 1000000 1000000 1000000 1000000 1 1 1 1000000 1 1 1000000 1 1000000 1000000 1 1000000 1 1 1 1 1000000 1 1 1000000 1000000 1000000 1000000 1 1000000 1 1 1 1 1 1 1 1 1 1 1000000 1 1000000 1000000 1000000 1 1000000 1 1000000 ...

output:

56999943 264036312

result:

ok 2 number(s): "56999943 264036312"

Test #49:

score: 0
Accepted
time: 1ms
memory: 3568kb

input:

2000 1000
1 1000000 1000000 1 1 1000000 1 1 1 1 1000000 1000000 1 1 1000000 1 1000000 1000000 1000000 1000000 1 1000000 1000000 1 1 1 1 1 1000000 1 1 1 1000000 1 1000000 1 1000000 1000000 1 1 1 1 1 1000000 1000000 1000000 1 1000000 1 1 1000000 1 1000000 1000000 1 1 1 1000000 1000000 1 1000000 1 1 1 ...

output:

999999000 1

result:

ok 2 number(s): "999999000 1"

Test #50:

score: 0
Accepted
time: 1ms
memory: 3612kb

input:

2000 1
1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 10000...

output:

0 1999000

result:

ok 2 number(s): "0 1999000"

Test #51:

score: 0
Accepted
time: 1ms
memory: 3680kb

input:

2000 124
1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 100...

output:

0 960369567

result:

ok 2 number(s): "0 960369567"

Test #52:

score: 0
Accepted
time: 1ms
memory: 3672kb

input:

2000 1000
1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 1000000 10...

output:

0 36237869

result:

ok 2 number(s): "0 36237869"

Test #53:

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

input:

1998 666
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:

1332 651667502

result:

ok 2 number(s): "1332 651667502"

Test #54:

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

input:

1998 666
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1...

output:

1332 651667502

result:

ok 2 number(s): "1332 651667502"

Extra Test:

score: 0
Extra Test Passed