結果
| 問題 |
No.680 作れる数
|
| コンテスト | |
| ユーザー |
🍮かんプリン
|
| 提出日時 | 2020-06-08 16:53:15 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 619 bytes |
| コンパイル時間 | 1,894 ms |
| コンパイル使用メモリ | 157,304 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-12-25 22:55:35 |
| 合計ジャッジ時間 | 2,844 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 20 |
ソースコード
// 解説見て書いただけ
/**
* @FileName a.cpp
* @Author kanpurin
* @Created 2020.06.08 16:52:59
**/
#include "bits/stdc++.h"
using namespace std;
typedef long long ll;
ll f(int t) {
ll s = 0;
while(t) {
s += t;
t >>= 1;
}
return s;
}
int main() {
int n;cin >> n;
int l = -1,r = 1000000001;
while(r - l > 1) {
int mid = l + (r - l) / 2;
if (f(mid) >= n) {
r = mid;
}
else {
l = mid;
}
}
if (f(r) == n) {
puts("YES");
}
else {
puts("NO");
}
return 0;
}
🍮かんプリン