結果

問題 No.3503 Brackets Stack Query 2
コンテスト
ユーザー はじっこゆーれー
提出日時 2026-04-17 23:39:23
言語 Python3
(3.14.3 + numpy 2.4.4 + scipy 1.17.1)
コンパイル:
python3 -mpy_compile _filename_
実行:
python3 _filename_
結果
AC  
実行時間 511 ms / 2,000 ms
コード長 1,082 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 489 ms
コンパイル使用メモリ 20,696 KB
実行使用メモリ 89,816 KB
最終ジャッジ日時 2026-04-17 23:39:52
合計ジャッジ時間 18,794 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

import sys

def solve():
    input = sys.stdin.readline
    line = input().strip()
    if not line:
        return
    Q = int(line)

    char_h = [''] * (Q + 1)
    top_h = [0] * (Q + 1)
    prev_h = [0] * (Q + 1)
    size_h = [0] * (Q + 1)

    pos = 0

    for _ in range(Q):
        query = input().split()
        if not query:
            break

        if query[0] == '1':
            char = query[1]
            pos += 1
            char_h[pos] = char

            t1 = top_h[pos - 1]
            t2 = prev_h[t1] if t1 > 0 else 0

            if char == ')' and t1 > 0 and t2 > 0 and char_h[t1] == '|' and char_h[t2] == '(':
                top_h[pos] = prev_h[t2]
                size_h[pos] = size_h[pos - 1] - 2
                prev_h[pos] = 0
            else:
                top_h[pos] = pos
                prev_h[pos] = t1
                size_h[pos] = size_h[pos - 1] + 1
        else:
            pos -= 1

        if size_h[pos] == 0:
            sys.stdout.write("Yes\n")
        else:
            sys.stdout.write("No\n")

if __name__ == '__main__':
    solve()
0