結果
問題 | 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]*Nfor i in range(N):ans[S[i][0]] = nB[i]print(*ans)