結果
| 問題 |
No.281 門松と魔法(1)
|
| コンテスト | |
| ユーザー |
ckawatak
|
| 提出日時 | 2019-02-11 17:28:42 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,258 bytes |
| コンパイル時間 | 221 ms |
| コンパイル使用メモリ | 81,920 KB |
| 実行使用メモリ | 62,976 KB |
| 最終ジャッジ日時 | 2024-07-18 15:10:05 |
| 合計ジャッジ時間 | 4,874 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 54 WA * 1 TLE * 2 |
ソースコード
D = int(input())
H1 = int(input())
H2 = int(input())
H3 = int(input())
def is_kadomatsu(h1, h2, h3):
return h1 != h3 and ((h1 < h2 and h3 < h2) or (h2 < h1 and h2 < h3))
def magic(h):
return max(0, h-D)
def magic_until(h,t):
i = 0
while t <= h:
if t == 0 and h == 0:
return 0,float('inf')
h = magic(h)
i = i + 1
return h,i
def recheck(h1, h2, h3):
if is_kadomatsu(h1,h2,h3):
return True,0
else:
m = max(h1,h3)
n = min(h1,h3)
h4,i = magic_until(m,h2)
h5,j = magic_until(h2,n)
if i < j:
return is_kadomatsu(h4 if h1 == m else h1, h2, h4 if h3 == m else h3),i
else:
return is_kadomatsu(h1, h5, h3),j
def check(h1, h2, h3):
if D == 0:
return is_kadomatsu(h1, h2, h3),0
elif h1 == h2 and h2 == h3 and h1 == h3:
h1 = magic(magic(h1))
h3 = magic(h3)
return is_kadomatsu(h1,h2,h3),3
elif h1 == h3 and h1 != h2 and h3 != h2:
h1 = magic(h1)
if is_kadomatsu(h1,h2,h3):
return True,1
else:
return recheck(h1,h2,h3)
else:
return recheck(h1,h2,h3)
found,i = check(H1,H2,H3)
if found:
print(i)
else:
print(-1)
ckawatak