結果

問題 No.859 路線A、路線B、路線C
ユーザー roarisroaris
提出日時 2019-08-09 22:18:26
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 31 ms / 1,000 ms
コード長 943 bytes
コンパイル時間 107 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 10,880 KB
最終ジャッジ日時 2024-07-19 12:16:26
合計ジャッジ時間 1,129 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 12
権限があれば一括ダウンロードができます

ソースコード

diff #

x, y, z = map(int, input().split())
s0, t0 = input().split()
t0 = int(t0)
s1, t1 = input().split()
t1 = int(t1)

if s0 == 'A':
    if s1 == 'A':
        t0, t1 = min(t0, t1), max(t0, t1)
        ans = min(t1-t0, t0+y+x-t1, t0+z+x-t1)
    elif s1 == 'B':
        ans = min(t0+t1-1, x-t0+y-t1+1, t0+z+y-t1, x-t0+z+t1)
    else:
        ans = min(t0+t1-1, x-t0+z-t1+1, t0+y+z-t1, x-t0+y+t1)
elif s0 == 'B':
    if s1 == 'A':
        ans = min(t0+t1-1, y-t0+x-t1+1, t0+z+x-t1, y-t0+z+t1)
    elif s1 == 'B':
        t0, t1 = min(t0, t1), max(t0, t1)
        ans = min(t1-t0, t0+x+y-t1, t0+z+y-t1)
    else:
        ans = min(t0+t1-1, y-t0+z-t1+1, t0+x+z-t1, y-t0+x+t1)
else:
    if s1 == 'A':
        ans = min(t0+t1-1, z-t0+x-t1+1, t0+y+x-t1, z-t0+y+t1)
    elif s1 == 'B':
        ans = min(t0+t1-1, z-t0+y-t1+1, t0+x+y-t1, z-t0+x+t1)
    else:
        t0, t1 = min(t0, t1), max(t0, t1)
        ans = min(t1-t0, t0+x+z-t1, t0+y+z-t1)

print(ans)
0