結果
| 問題 | No.1894 Delete AB |
| コンテスト | |
| ユーザー |
tktk_snsn
|
| 提出日時 | 2022-04-08 21:53:55 |
| 言語 | Python3 (3.14.3 + numpy 2.4.4 + scipy 1.17.1) |
| 結果 |
AC
|
| 実行時間 | 166 ms / 2,000 ms |
| コード長 | 648 bytes |
| 記録 | |
| コンパイル時間 | 1,115 ms |
| コンパイル使用メモリ | 20,828 KB |
| 実行使用メモリ | 21,468 KB |
| 最終ジャッジ日時 | 2026-05-22 13:16:53 |
| 合計ジャッジ時間 | 4,136 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 1 |
| other | AC * 14 |
ソースコード
def solve():
N = int(input())
S = list(input())
S.append("?")
prev = [-1] * N
stack = []
for i in range(N):
if S[i] == "A":
stack.append(i)
else:
if stack:
prev[i] = stack.pop()
ans = [N]
i = N - 1
while i >= 0:
if prev[i] == -1:
ans.append(i)
i -= 1
else:
if S[ans[-1]] != "B":
ans.append(i)
i -= 1
else:
i = prev[i] - 1
ans.reverse()
ans.pop()
print("".join(S[i] for i in ans))
T = int(input())
for _ in range(T):
solve()
tktk_snsn