結果

問題 No.3557 KCPC or KUPC 2
コンテスト
ユーザー t98slider
提出日時 2026-06-07 16:57:37
言語 C++23
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++23 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
WA  
実行時間 -
コード長 1,032 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 4,109 ms
コンパイル使用メモリ 333,336 KB
実行使用メモリ 6,400 KB
最終ジャッジ日時 2026-06-07 16:57:50
合計ジャッジ時間 12,787 ms
ジャッジサーバーID
(参考情報)
judge1_1 / judge2_0
このコードへのチャレンジ
(要ログイン)
サブタスク 配点 結果
部分点1 10 % AC * 23 WA * 7
部分点2 40 % AC * 27 WA * 3
部分点3 50 % AC * 28 WA * 2
合計 0 点
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include <bits/stdc++.h>
using namespace std;
using ll = long long;

template<typename T>
T ADD(T a, T b){
    T res;
    return __builtin_add_overflow(a, b, &res)? std::numeric_limits<T>::max() : res;
}
template<typename T>
T MUL(T a, T b){
    T res;
    return __builtin_mul_overflow(a, b, &res)? std::numeric_limits<T>::max() : res;
}

int main(){
    ios::sync_with_stdio(false);
    cin.tie(0);
    ll n;
    cin >> n;
    vector<ll> a(3), b(3);
    for(auto &&v : a) cin >> v;
    for(auto &&v : b) cin >> v;
    auto f = [&](vector<ll> a){
        ll ng = 0, ok = n;
        while(ng + 1 < ok){
            ll mid = (ng + ok) / 2;
            ll up = (mid - 1) / a[1];
            ll sv = ADD(MUL(a[0], mid), MUL(MUL(a[2], a[1]), MUL(up, up - 1) / 2));
            sv = ADD(sv, MUL((mid - 1) % a[1], MUL(a[2], up)));
            (sv >= n ? ok : ng) = mid;
        }
        return ok;
    };
    ll v0 = f(a), v1 = f(b);
    if(v0 == v1) cout << "Same\n";
    else if(v0 < v1) cout << "KCPC\n";
    else cout << "KUPC\n";
}
0