結果
問題 |
No.1286 Stone Skipping
|
ユーザー |
![]() |
提出日時 | 2020-11-14 00:00:00 |
言語 | C++17 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 4 ms / 2,000 ms |
コード長 | 630 bytes |
コンパイル時間 | 2,739 ms |
コンパイル使用メモリ | 191,496 KB |
最終ジャッジ日時 | 2025-01-16 00:10:44 |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 26 |
ソースコード
#include <bits/stdc++.h> using namespace std; long long d; long long solve(); long long calc(int k, long long x); int main() { cin >> d; cout << solve() << endl; return 0; } long long solve() { long long res = d; for (int i = 1; i < 62; ++i) { long long l = 0, r = 1e18; while (r - l > 1) { long long mid = (l + r) >> 1; if (calc(i, mid) >= d) r = mid; else l = mid; } if (calc(i, r) == d) res = min(res, r); } return res; } long long calc(int k, long long x) { long long res = 0; for (int i = 0; i < k; ++i) { res += x; x >>= 1; } return res; }