結果
問題 |
No.2482 Sandglasses
|
ユーザー |
![]() |
提出日時 | 2024-12-22 04:47:51 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 528 ms / 2,000 ms |
コード長 | 735 bytes |
コンパイル時間 | 410 ms |
コンパイル使用メモリ | 82,176 KB |
実行使用メモリ | 160,336 KB |
最終ジャッジ日時 | 2024-12-22 04:48:11 |
合計ジャッジ時間 | 18,001 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 25 |
ソースコード
N, K, T = map(int, input().split()) A = list(input().split()) B = list(map(int, input().split())) nB = [] for i in range(N): if A[i] == "A": if B[i] > T: nB.append(B[i]-T) else: if (T-B[i])%(K*2) < K: nB.append((T-B[i])%(K*2)) else: nB.append(K-(T-B[i])%(K*2)+K) else: if K-B[i] > T: nB.append(K-((K-B[i])-T)) else: if (T-(K-B[i]))%(K*2) < K: nB.append(K-(T-(K-B[i]))%(K*2)) else: nB.append((T-(K-B[i]))%(K*2)-K) S = sorted([(i, b) for i, b in enumerate(B)], key=lambda x:x[1]) nB.sort() ans = [-1]*N for i in range(N): ans[S[i][0]] = nB[i] print(*ans)