結果

問題 No.378 名声値を稼ごう
ユーザー takeya_okinotakeya_okino
提出日時 2017-06-19 21:59:15
言語 Java11
(openjdk 11.0.7)
結果
AC  
実行時間 121 ms / 2,000 ms
コード長 620 Byte
コンパイル時間 2,026 ms
使用メモリ 24,860 KB
最終ジャッジ日時 2020-06-15 12:58:46

テストケース

テストケース表示
入力 結果 実行時間
使用メモリ
testcase_00 AC 113 ms
24,796 KB
testcase_01 AC 115 ms
24,852 KB
testcase_02 AC 115 ms
24,812 KB
testcase_03 AC 114 ms
24,860 KB
testcase_04 AC 121 ms
24,840 KB
testcase_05 AC 120 ms
24,808 KB
権限があれば一括ダウンロードができます

ソースコード

diff #
import java.util.*;

public class Main {
  public static void main(String[] args) {
    Scanner sc = new Scanner(System.in);
    long N = sc.nextLong();
    long normal = 0;
    long score = N;
    for(int i = 0; i < 61; i++) {
      if(score > 0) {
        normal += score;
        score /= 2;
      } else {
        break;
      }
    }
    long skill = 0;
    for(int i = 0; i < 61; i++) {
      score = N;
      long a = 0;
      for(int j = 0; j < i; j++) {
        a += score;
        score /= 2;
      }
      a += (2 * score);
      skill = Math.max(skill, a);
    }
    System.out.println(skill - normal);
  }
}
0