結果
問題 | No.968 引き算をして門松列(その3) |
ユーザー | 👑 SPD_9X2 |
提出日時 | 2020-01-13 22:18:36 |
言語 | Python3 (3.12.2 + numpy 1.26.4 + scipy 1.12.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,086 bytes |
コンパイル時間 | 98 ms |
コンパイル使用メモリ | 12,672 KB |
実行使用メモリ | 10,880 KB |
最終ジャッジ日時 | 2024-06-02 07:01:05 |
合計ジャッジ時間 | 2,044 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 31 ms
10,752 KB |
testcase_01 | AC | 27 ms
10,752 KB |
testcase_02 | WA | - |
testcase_03 | AC | 94 ms
10,624 KB |
testcase_04 | AC | 99 ms
10,752 KB |
testcase_05 | AC | 103 ms
10,752 KB |
testcase_06 | AC | 104 ms
10,752 KB |
testcase_07 | AC | 103 ms
10,624 KB |
testcase_08 | AC | 156 ms
10,752 KB |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
ソースコード
T = int(input()) for i in range(T): a,b,c,x,y,z = map(int,input().split()) A = 10**10-a B = 10**10-b C = 10**10-c Z = x Y = z X = y ans = float("inf") #A>C>B na = A nc = min(A-1,C) nb = min(nc-1,B) if min(a - (B-nb+C-nc) , b - (A-na+C-nc) , c - (B-nb+A-na)) > 0: ans = min(ans, (A-na)*X + (B-nb)*Y + (C-nc)*Z) #B>C>A nb = B nc = min(B-1,C) na = min(nc-1,A) if min(a - (B-nb+C-nc) , b - (A-na+C-nc) , c - (B-nb+A-na)) > 0: ans = min(ans, (A-na)*X + (B-nb)*Y + (C-nc)*Z) t = A A = C C = t s = X X = Z Z = s #A>C>B na = A nc = min(A-1,C) nb = min(nc-1,B) if min(a - (B-nb+C-nc) , b - (A-na+C-nc) , c - (B-nb+A-na)) > 0: ans = min(ans, (A-na)*X + (B-nb)*Y + (C-nc)*Z) #B>C>A nb = B nc = min(B-1,C) na = min(nc-1,A) if min(a - (B-nb+C-nc) , b - (A-na+C-nc) , c - (B-nb+A-na)) > 0: ans = min(ans, (A-na)*X + (B-nb)*Y + (C-nc)*Z) if ans == float("inf"): print (-1) else: print (ans)