結果

問題 No.967 引き算をして門松列(その2)
ユーザー 👑 SPD_9X2
提出日時 2020-01-13 21:47:29
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
WA  
実行時間 -
コード長 2,216 bytes
コンパイル時間 208 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 11,136 KB
最終ジャッジ日時 2024-12-23 00:16:13
合計ジャッジ時間 1,812 ms
ジャッジサーバーID
(参考情報)
judge2 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1 WA * 1
other AC * 1 WA * 9
権限があれば一括ダウンロードができます

ソースコード

diff #

T = int(input())

for i in range(T):

    A,B,C,X,Y,Z= map(int,input().split())
    

    if A==B and B==C:

        if A < 3:
            print (-1)
        else:
            print (min(X+Z*2,X*2+Z,Y*2+X,Y*2+Z))

    elif A==B or B==C:
        if B == 1:
            print (-1)
        elif abs(A-C) == 1: #1 2 2 or 2 2 3

            #A=Bにする
            if B==C:
                t = C
                C = A
                A = t
                s = X
                X = Z
                Z = s
            
            
            if min(A,B,C) == 1:
                print (-1)
            elif min(A,B,C) < B: #3 3 2 / 5 5 4など
                if C > 1:
                    print (min(X*2,Y*2,X+Z))
            else: #5 5 6/ 3 3 4など
                print (min(X,Y))

        else: #9 9 3/2 2 5など

            #A=Bにする
            if B==C:
                t = C
                C = A
                A = t
                s = X
                X = Z
                Z = s

            if C<A or B<=2:
                print (X)
            else: #2 2 5
                
                print (min(X, Y+(C-(B-2))*Z, 2*Y+(C-(B-1))*Z ) )
            
    elif A == C:
        if A != 1 and B != A-1: #2 3 2
            print (min(X,Z))
        elif A != 1 and B == A-1 and A-2 > 0: #3 2 3
            print (min(X*2,Z*2,X+Y,Y+Z))
        else:
            print (-1)

    else: #9 2 1

        ans = float("inf")

        if min(A,B,C) == B or max(A,B,C) == B:
            print (0)
        else:
            ans = float("inf")

            if A < C: #A>B>Cにする
                t = C
                C = A
                A = t
                s = X
                X = Z
                Z = s
            
            na = B-1

            if na != C and na > 0:
                ans = min(ans,(A-na)*X)
            elif na > 0:
                ans = min(ans,(A-na)*X+Z)
            
            na = C-1

            if na > 0:
                ans = min(ans,(A-na)*X)

            

            nb = C-1
            if nb > 0:
                ans = min(ans,(B-nb)*Y)

            if ans == float("inf"):
                print (-1)
            else:
                print (ans)
        

0