QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#802829#9864. Coinucup-team987#WA 107ms3820kbC++2311.8kb2024-12-07 14:52:212024-12-07 14:52:27

Judging History

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

  • [2024-12-07 14:52:27]
  • 评测
  • 测评结果:WA
  • 用时:107ms
  • 内存:3820kb
  • [2024-12-07 14:52:21]
  • 提交

answer

/**
 * date   : 2024-12-07 15:52:10
 * 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))
#endif
#ifndef NyaanDebug
#define trc(...) (void(0))
#endif

#ifndef NyaanLocal
#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(); }


//



using namespace std;

struct Timer {
  chrono::high_resolution_clock::time_point st;

  Timer() { reset(); }
  void reset() { st = chrono::high_resolution_clock::now(); }

  long long elapsed() {
    auto ed = chrono::high_resolution_clock::now();
    return chrono::duration_cast<chrono::milliseconds>(ed - st).count();
  }
  long long operator()() { return elapsed(); }
};


using namespace Nyaan;

ll d(ll a, ll b) { return 1.0 * a / b; }

ll f(ll N, ll K) {
  ll res = 0;
  for (ll n = N; n > 0;) {
    ll q = d(n + K - 1, K);
    // n が (q-1)*K+1 以上である間 n-=q
    ll num = d(n - ((q - 1) * K + 1), q) + 1;
    res += num;
    n -= q * num;
  }
  return res;
}

void q() {
  inl(N, K);
  ll T = f(N, K);
  T--;
  ll n = 1;

  trc(N, K, T);
  while (T) {
    ll q = d(n + K - 1, K);
    if (n >= K * K) {
      ll ng = 1, ok = n + 1;
      while (ng + 1 < ok) {
        ll m = (ng + ok) / 2;
        (d(m * K - n, m) > 0 ? ok : ng) = m;
      }
      q = ok;
    }
    // if(T<=100)trc2(T,q);
    // n が qK-q 以下である間 n+=q,T--;
    ll num = d(q * K - n, q);
    while (num == 0) {
      q++;
      num = d(q * K - n, q);
    }
    amin(num, T);
    n += num * q;
    T -= num;
  }
  out(n);
}

void Nyaan::solve() {
  Timer timer;
  ll t = 1;
  in(t);
  while (t--) q();
  trc2(timer());
}

Details

Tip: Click on the bar to expand more detailed information

Test #1:

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

input:

4
6 2
8 3
10000 2
1919810 114514

output:

4
8
8192
1919805

result:

ok 4 number(s): "4 8 8192 1919805"

Test #2:

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

input:

100
2 2
2 3
2 4
2 5
2 6
2 7
2 8
2 9
2 10
2 11
3 2
3 3
3 4
3 5
3 6
3 7
3 8
3 9
3 10
3 11
4 2
4 3
4 4
4 5
4 6
4 7
4 8
4 9
4 10
4 11
5 2
5 3
5 4
5 5
5 6
5 7
5 8
5 9
5 10
5 11
6 2
6 3
6 4
6 5
6 6
6 7
6 8
6 9
6 10
6 11
7 2
7 3
7 4
7 5
7 6
7 7
7 8
7 9
7 10
7 11
8 2
8 3
8 4
8 5
8 6
8 7
8 8
8 9
8 10
8 11
9 ...

output:

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

result:

ok 100 numbers

Test #3:

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

input:

100
100 10
100 11
100 12
100 13
100 14
100 15
100 16
100 17
100 18
100 19
101 10
101 11
101 12
101 13
101 14
101 15
101 16
101 17
101 18
101 19
102 10
102 11
102 12
102 13
102 14
102 15
102 16
102 17
102 18
102 19
103 10
103 11
103 12
103 13
103 14
103 15
103 16
103 17
103 18
103 19
104 10
104 11
10...

output:

93
94
92
98
98
94
96
100
96
95
93
94
101
98
98
101
96
100
96
101
93
94
101
98
98
101
96
100
102
101
93
94
101
98
98
101
103
100
102
101
104
104
101
98
98
101
103
100
102
101
104
104
101
98
98
101
103
100
102
101
104
104
101
98
106
101
103
100
102
101
104
104
101
107
106
101
103
107
102
107
104
104
1...

result:

ok 100 numbers

Test #4:

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

input:

100
10000 2
10000 3
10000 4
10000 5
10000 6
10000 7
10000 8
10000 9
10000 10
10000 11
10001 2
10001 3
10001 4
10001 5
10001 6
10001 7
10001 8
10001 9
10001 10
10001 11
10002 2
10002 3
10002 4
10002 5
10002 6
10002 7
10002 8
10002 9
10002 10
10002 11
10003 2
10003 3
10003 4
10003 5
10003 6
10003 7
10...

output:

8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
8192
8091
8719
8279
9885
8980
8933
9756
9938
9526
...

result:

ok 100 numbers

Test #5:

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

input:

100
10000 10
10000 11
10000 12
10000 13
10000 14
10000 15
10000 16
10000 17
10000 18
10000 19
10001 10
10001 11
10001 12
10001 13
10001 14
10001 15
10001 16
10001 17
10001 18
10001 19
10002 10
10002 11
10002 12
10002 13
10002 14
10002 15
10002 16
10002 17
10002 18
10002 19
10003 10
10003 11
10003 12...

output:

9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
9938
9526
9903
9913
9713
9441
9949
9599
9984
9683
...

result:

ok 100 numbers

Test #6:

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

input:

100
100000 100
100000 101
100000 102
100000 103
100000 104
100000 105
100000 106
100000 107
100000 108
100000 109
100001 100
100001 101
100001 102
100001 103
100001 104
100001 105
100001 106
100001 107
100001 108
100001 109
100002 100
100002 101
100002 102
100002 103
100002 104
100002 105
100002 106...

output:

99125
99684
99115
99174
99331
99117
99518
99951
99671
99544
99125
99684
99115
99174
99331
99117
99518
99951
99671
99544
99125
99684
99115
99174
99331
99117
99518
99951
99671
99544
99125
99684
99115
99174
99331
99117
99518
99951
99671
99544
99125
99684
99115
99174
99331
99117
99518
99951
99671
99544
...

result:

ok 100 numbers

Test #7:

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

input:

100
9829300000 1000000000
9829300000 1000000001
9829300000 1000000002
9829300000 1000000003
9829300000 1000000004
9829300000 1000000005
9829300000 1000000006
9829300000 1000000007
9829300000 1000000008
9829300000 1000000009
9829300001 1000000000
9829300001 1000000001
9829300001 1000000002
9829300001...

output:

9829299995
9829299995
9829299997
9829300000
9829299999
9829299991
9829300000
9829299991
9829299999
9829299995
9829299995
9829299995
9829299997
9829300000
9829299999
9829300001
9829300000
9829300001
9829299999
9829299995
9829299995
9829299995
9829299997
9829300000
9829299999
9829300001
9829300000
982...

result:

ok 100 numbers

Test #8:

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

input:

100
9999381928 1232
9999381928 1233
9999381928 1234
9999381928 1235
9999381928 1236
9999381928 1237
9999381928 1238
9999381928 1239
9999381928 1240
9999381928 1241
9999381929 1232
9999381929 1233
9999381929 1234
9999381929 1235
9999381929 1236
9999381929 1237
9999381929 1238
9999381929 1239
99993819...

output:

9995638846
9993981206
9997382406
9994865205
9994009665
9995914019
9997757681
9993825977
9999146806
9993973586
9995638846
9993981206
9997382406
9994865205
9994009665
9995914019
9997757681
9993825977
9999146806
9993973586
9995638846
9993981206
9997382406
9994865205
9994009665
9995914019
9997757681
999...

result:

ok 100 numbers

Test #9:

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

input:

100
9182736475 2938475612
9182736475 2938475613
9182736475 2938475614
9182736475 2938475615
9182736475 2938475616
9182736475 2938475617
9182736475 2938475618
9182736475 2938475619
9182736475 2938475620
9182736475 2938475621
9182736476 2938475612
9182736476 2938475613
9182736476 2938475614
9182736476...

output:

9182736474
9182736474
9182736473
9182736473
9182736472
9182736473
9182736472
9182736472
9182736475
9182736475
9182736474
9182736474
9182736473
9182736473
9182736476
9182736473
9182736476
9182736476
9182736475
9182736475
9182736474
9182736474
9182736477
9182736477
9182736476
9182736477
9182736476
918...

result:

ok 100 numbers

Test #10:

score: -100
Wrong Answer
time: 0ms
memory: 3664kb

input:

100
1827364563 8192837167
1827364563 8192837168
1827364563 8192837169
1827364563 8192837170
1827364563 8192837171
1827364563 8192837172
1827364563 8192837173
1827364563 8192837174
1827364563 8192837175
1827364563 8192837176
1827364564 8192837167
1827364564 8192837168
1827364564 8192837169
1827364564...

output:

3654729125
3654729125
3654729125
3654729125
3654729125
3654729125
3654729125
3654729125
3654729125
3654729125
3654729127
3654729127
3654729127
3654729127
3654729127
3654729127
3654729127
3654729127
3654729127
3654729127
3654729129
3654729129
3654729129
3654729129
3654729129
3654729129
3654729129
365...

result:

wrong answer 1st numbers differ - expected: '1827364563', found: '3654729125'