結果

問題 No.1101 鼻水
コンテスト
ユーザー fastmath
提出日時 2020-07-04 00:19:37
言語 C++14
(gcc 15.2.0 + boost 1.89.0)
コンパイル:
g++-15 -O2 -lm -std=c++14 -Wuninitialized -DONLINE_JUDGE -o a.out _filename_
実行:
./a.out
結果
WA  
実行時間 -
コード長 1,104 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 1,209 ms
コンパイル使用メモリ 178,768 KB
実行使用メモリ 6,400 KB
最終ジャッジ日時 2026-04-06 03:09:02
合計ジャッジ時間 1,913 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge2_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 10 WA * 12
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define ii pair <int, int>
#define app push_back
#define all(a) a.begin(), a.end()
#define bp __builtin_popcountll
#define ll long long
#define mp make_pair
#define f first
#define s second
#define Time (double)clock()/CLOCKS_PER_SEC
#define debug(x) std::cout << #x << ": " << x << '\n';

const int INF = 5e18+7;

signed main() {
    #ifdef HOME
    freopen("input.txt", "r", stdin);
    #else
    #define endl '\n'
    ios_base::sync_with_stdio(0); cin.tie(0);
    #endif
    
    int v, t, p;
    cin >> v >> t >> p;

    auto get = [&](int n) {
        return (n + t - 1) / t;
    };

    int start = 0;
    {
    int l = 0, r = INF;
    while (l < r - 1) {
        int m = (l + r) >> 1;
        if (m - get(m) > v * p)
            r = m;
        else
            l = m;            
    }   
    start = l;
    }

    int l = start, r = INF;
    while (l < r - 1) {
        int m = (l + r) >> 1;
        if ((m - start) - (get(m) - get(start)) > v)
            r = m;
        else
            l = m;
    }   
    cout << l << endl;
}
0