結果

問題 No.592 括弧の対応 (2)
ユーザー kohei2019kohei2019
提出日時 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
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 45 ms
53,248 KB
testcase_01 AC 140 ms
104,192 KB
testcase_02 AC 147 ms
115,968 KB
testcase_03 AC 112 ms
91,520 KB
権限があれば一括ダウンロードができます

ソースコード

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