結果
問題 | No.592 括弧の対応 (2) |
ユーザー | バカらっく |
提出日時 | 2017-11-10 22:38:55 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
AC
|
実行時間 | 66 ms / 5,000 ms |
コード長 | 1,564 bytes |
コンパイル時間 | 856 ms |
コンパイル使用メモリ | 114,132 KB |
実行使用メモリ | 30,592 KB |
最終ジャッジ日時 | 2024-11-24 12:54:04 |
合計ジャッジ時間 | 1,701 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 3 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System; using System.IO; using System.Linq; using System.Collections.Generic; using System.Text; public class Program { public void Proc() { int length = int.Parse(Reader.ReadLine()); string inpt = Reader.ReadLine(); Stack<int> stk = new Stack<int>(); int[] ans = new int[length]; for (int i = 0; i < inpt.Length; i++) { if(inpt[i] == ')') { if(stk.Count>0) { int tmp = stk.Pop(); ans[tmp] = i + 1; ans[i] = tmp + 1; } } else if(inpt[i] == '(') { stk.Push(i); } } StringBuilder ansText = new StringBuilder(); ans.ToList().ForEach(a=>ansText.AppendLine(a.ToString())); Console.Write(ansText.ToString()); } public class Reader { private static StringReader sr; public static bool IsDebug = false; public static string ReadLine() { if (IsDebug) { if (sr == null) { sr = new StringReader(InputText.Trim()); } return sr.ReadLine(); } else { return Console.ReadLine(); } } private static string InputText = @" 6 ()(()) "; } public static void Main(string[] args) { #if DEBUG Reader.IsDebug = true; #endif Program prg = new Program(); prg.Proc(); } }