백준 9012번, 괄호
백준 9012번 c++ 문제풀이
문제:
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다.
그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
풀이:
- ’)’ 일 때는 stack이 비워져 다면 break 하고 “NO” 출력
- ’(‘ 일 때는 문자열 마지막인지 확인하고 마지막으면 “NO” 출력
- ’(‘ 이 마지막이 아니라면 stack에 push한다.
- 위의 과정을 다하고 나서 stack이 empty라면 “YES” 출력한다.
- 반복문이 끝나면 다음 문자열의 결과를 확인하기 위해 stack을 초기화한다.
코드:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#include <iostream>
#include <stack>
#include <algorithm>
using namespace std;
stack <char> s;
int main(){
int n;
cin >> n;
for(int i=0;i<n;i++){
string input;
int len = 0;
cin >> input;
len = input.length();
while( !s.empty() )
{
s.pop();
}
for(int j=0;j<len;j++){
if(input[j] == ')'){
if(s.empty()){
cout << "NO\n";
break;
}
else if(s.top() == '('){
s.pop();
if(j==len-1){
if(s.empty()){
cout << "YES\n";
}else{
cout << "NO\n";
}
}
}
}
else if(input[j] == '('){
if(j == (len - 1)){
cout << "NO\n";
break;
}else{
s.push(input[j]);
}
}
}
}
return 0;
}
감사합니다.
This post is licensed under CC BY 4.0 by the author.