結果

問題 No.1010 折って重ねて
ユーザー lam6er
提出日時 2025-03-20 20:29:25
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 40 ms / 2,000 ms
コード長 586 bytes
コンパイル時間 299 ms
コンパイル使用メモリ 82,588 KB
実行使用メモリ 53,880 KB
最終ジャッジ日時 2025-03-20 20:30:19
合計ジャッジ時間 3,574 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 43
権限があれば一括ダウンロードができます

ソースコード

diff #

def max_folds(val_mm, initial_h):
    a = 0
    current_val = val_mm * 1.0
    current_h = initial_h * 1.0
    while current_val > current_h:
        a += 1
        current_val /= 2.0
        current_h *= 2.0
    return a

x, y, h = map(int, input().split())

# Case 1: Fold x first, then y
a = max_folds(x * 1000, h)
h_new_x = h * (2 ** a)
b = max_folds(y * 1000, h_new_x)
total1 = a + b

# Case 2: Fold y first, then x
b_initial = max_folds(y * 1000, h)
h_new_y = h * (2 ** b_initial)
a_initial = max_folds(x * 1000, h_new_y)
total2 = b_initial + a_initial

print(max(total1, total2))
0