結果
| 問題 | No.680 作れる数 | 
| コンテスト | |
| ユーザー |  yuruhiya | 
| 提出日時 | 2021-01-31 12:29:14 | 
| 言語 | Crystal (1.14.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 2 ms / 2,000 ms | 
| コード長 | 323 bytes | 
| コンパイル時間 | 11,850 ms | 
| コンパイル使用メモリ | 296,196 KB | 
| 実行使用メモリ | 6,944 KB | 
| 最終ジャッジ日時 | 2024-06-30 22:18:32 | 
| 合計ジャッジ時間 | 12,762 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 20 | 
ソースコード
lib C
  fun strtoll(s : UInt8*, p : UInt8**, b : Int32) : Int64
end
class String
  def to_i64
    C.strtoll(self, nil, 10)
  end
end
def func(n)
  x = 0i64
  while n > 0
    x += n
    n //= 2
  end
  x
end
n = read_line.to_i64
x = (1..n).bsearch { |x| func(x) >= n }
puts n == 0 || func(x.not_nil!) == n ? "YES" : "NO"
            
            
            
        