반응형
[ 문제 ]
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다. 그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
[ 코드 ]
using System.Text;
StreamReader sr = new StreamReader(new BufferedStream(Console.OpenStandardInput()));
StreamWriter sw = new StreamWriter(new BufferedStream(Console.OpenStandardOutput()));
StringBuilder sb = new StringBuilder();
int n = int.Parse(sr.ReadLine());
for (int i = 0; i < n; i++)
{
string input = sr.ReadLine();
bool check = stackCheck(input);
if (check)
{
sb.AppendLine("YES");
}
else
{
sb.AppendLine("NO");
}
}
sw.Write(sb.ToString());
sw.Flush();
sw.Close();
sr.Close();
bool stackCheck(string s)
{
Stack<char> stack = new Stack<char>();
foreach (char c in s)
{
if (c == '(')
{
stack.Push(c);
}
else if (c == ')')
{
if (stack.Count == 0 || stack.Pop() != '(')
{
return false;
}
}
}
return stack.Count == 0;
}
[ 실행화면 ]
문제링크: https://www.acmicpc.net/problem/9012
9012번: 괄호
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고
www.acmicpc.net
반응형
'Language > C#' 카테고리의 다른 글
[C#] 백준 1076번 저항 (0) | 2024.02.27 |
---|---|
[C#] 백준 1009번 분산처리 (0) | 2024.02.27 |
[C#] 백준 1371번 가장 많은 글자 (0) | 2024.02.25 |
[C#] 백준 10815번 숫자 카드 (0) | 2024.02.24 |
[C#] 백준 10773번 제로 (0) | 2024.02.24 |