結果

問題 No.592 括弧の対応 (2)
ユーザー kohei2019
提出日時 2022-02-15 00:43:04
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 147 ms / 5,000 ms
コード長 427 bytes
コンパイル時間 158 ms
コンパイル使用メモリ 82,304 KB
実行使用メモリ 115,968 KB
最終ジャッジ日時 2024-06-29 06:57:40
合計ジャッジ時間 1,243 ms
ジャッジサーバーID
(参考情報)
judge2 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 3
権限があれば一括ダウンロードができます

ソースコード

diff #

import collections
N = int(input())
S = input()
lsi = []
ii = 0

for i in range(N):
    if S[i] == '(':
        lsi.append(ii)
        ii += 1
    else:
        ii -= 1
        lsi.append(ii)

d = collections.defaultdict(list)
ans = [0]*(N)
for i in range(N):
    if d[lsi[i]] != []:
        p = d[lsi[i]].pop()
        ans[i] = p
        ans[p] = i
    else:
        d[lsi[i]].append(i)

for i in range(N):
    print(ans[i]+1)
0