結果

問題 No.2526 Kth Not-divisible Number
ユーザー cubinglovercubinglover
提出日時 2023-11-03 21:29:14
言語 C++17
(gcc 12.3.0 + boost 1.83.0)
結果
AC  
実行時間 367 ms / 2,000 ms
コード長 1,564 bytes
コンパイル時間 2,077 ms
コンパイル使用メモリ 202,060 KB
実行使用メモリ 4,348 KB
最終ジャッジ日時 2023-11-03 21:29:36
合計ジャッジ時間 6,838 ms
ジャッジサーバーID
(参考情報)
judge14 / judge13
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
4,348 KB
testcase_01 AC 2 ms
4,348 KB
testcase_02 AC 1 ms
4,348 KB
testcase_03 AC 342 ms
4,348 KB
testcase_04 AC 350 ms
4,348 KB
testcase_05 AC 342 ms
4,348 KB
testcase_06 AC 344 ms
4,348 KB
testcase_07 AC 367 ms
4,348 KB
testcase_08 AC 324 ms
4,348 KB
testcase_09 AC 321 ms
4,348 KB
testcase_10 AC 327 ms
4,348 KB
testcase_11 AC 311 ms
4,348 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

#include <bits/stdc++.h>
using namespace std;
#define repl(i, l, r) for (ll i = (l); i < (ll)(r); ++i)
#define rep(i, n) repl(i, 0, n)
#define CST(x) cout << fixed << setprecision(x)
#define all(x) (x).begin(), (x).end()
#define sz(x) (int)(x).size()
using ll = long long;
using ld = long double;
constexpr ll MOD = 998244353;
constexpr int inf = 1e9 + 10;
constexpr ll INF = (ll)4e18 + 10;
constexpr int dx[9] = {1, 0, -1, 0, 1, -1, -1, 1, 0};
constexpr int dy[9] = {0, 1, 0, -1, 1, 1, -1, -1, 0};
template <typename T>
using MaxHeap = priority_queue<T>;
template <typename T>
using MinHeap = priority_queue<T, vector<T>, greater<T>>;
template <typename T>
inline bool chmax(T &a, T b) {
    return ((a < b) ? (a = b, true) : (false));
}
template <typename T>
inline bool chmin(T &a, T b) {
    return ((a > b) ? (a = b, true) : (false));
}
template <typename T>
inline void yn(const T &a) {
    ((a) ? (cout << "Yes" << endl) : (cout << "No" << endl));
}
template <typename T>
inline void YN(const T &a) {
    ((a) ? (cout << "YES" << endl) : (cout << "NO" << endl));
}
void solve() {
    ll a, b, k;
    cin >> a >> b >> k;

    ll t = lcm(a, b);

    ll l = -1, r = INF;

    while (r - l > 1) {
        ll m = (l + r) / 2;
        ll cnt = m - m / a - m / b + m / t;

        if (cnt < k) {
            l = m;
        } else {
            r = m;
        }
    }

    cout << r << endl;

    return;
}
int main() {
    cin.tie(nullptr);
    cout.tie(nullptr);
    ios::sync_with_stdio(false);

    int t;
    cin >> t;
    while (t--) solve();

    return 0;
}
0