괄호
다국어
1 초 | 128 MB | 150526 | 69535 | 50166 | 45.133% |
문제
괄호 문자열(Parenthesis String, PS)은 두 개의 괄호 기호인 ‘(’ 와 ‘)’ 만으로 구성되어 있는 문자열이다. 그 중에서 괄호의 모양이 바르게 구성된 문자열을 올바른 괄호 문자열(Valid PS, VPS)이라고 부른다. 한 쌍의 괄호 기호로 된 “( )” 문자열은 기본 VPS 이라고 부른다. 만일 x 가 VPS 라면 이것을 하나의 괄호에 넣은 새로운 문자열 “(x)”도 VPS 가 된다. 그리고 두 VPS x 와 y를 접합(concatenation)시킨 새로운 문자열 xy도 VPS 가 된다. 예를 들어 “(())()”와 “((()))” 는 VPS 이지만 “(()(”, “(())()))” , 그리고 “(()” 는 모두 VPS 가 아닌 문자열이다.
여러분은 입력으로 주어진 괄호 문자열이 VPS 인지 아닌지를 판단해서 그 결과를 YES 와 NO 로 나타내어야 한다.
입력
입력 데이터는 표준 입력을 사용한다. 입력은 T개의 테스트 데이터로 주어진다. 입력의 첫 번째 줄에는 입력 데이터의 수를 나타내는 정수 T가 주어진다. 각 테스트 데이터의 첫째 줄에는 괄호 문자열이 한 줄에 주어진다. 하나의 괄호 문자열의 길이는 2 이상 50 이하이다.
출력
출력은 표준 출력을 사용한다. 만일 입력 괄호 문자열이 올바른 괄호 문자열(VPS)이면 “YES”, 아니면 “NO”를 한 줄에 하나씩 차례대로 출력해야 한다.
예제 입력 1 복사
6
(())())
(((()())()
(()())((()))
((()()(()))(((())))()
()()()()(()()())()
(()((())()(
예제 출력 1 복사
NO
NO
YES
NO
YES
NO
예제 입력 2 복사
3
((
))
())(()
예제 출력 2 복사
NO
NO
NO
https://www.acmicpc.net/problem/9012
흐름
코드
#include <bits/stdc++.h>
using namespace std;
int n;
string s;
stack<char> st;
bool noVps;
int main(){
ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
//1. 입력받기
cin >> n;
while(n--){
cin >> s;
//2. 올바른 괄호 문자열인지 확인하기
for(char c:s){
if(c=='(') {
st.push('(');
}
else if (c==')') {
if(st.size()) {
st.pop();
}
else { // ex: ())인 경우
//3. 출력하기
cout << "NO\n";
noVps=true;
break;
}
}
}
//ex: (() 인 경우
if (st.size()) cout << "NO\n";
else if(!noVps) cout << "YES\n";
//4. 초기화 하기
while(!st.empty()) st.pop();
noVps=false;
}
return 0;
}
선생님 코드를 보니 더 깔끔하고 짧다.
선생님 코드
#include <bits/stdc++.h>
using namespace std;
int n;
string s;
bool check(string s){
stack<char> stk; //지역변수로 선언하면 초기화 안해도 됨
for(char c:s){
if(c=='(') stk.push(c);
else{
if(!stk.empty()) stk.pop();
else return false;
}
}
return stk.empty();
}
int main(){
//1. 입력하기
cin >> n;
for(int i=0;i<n;i++){
cin >> s;
//2. 괄호 문자열 확인 후 출력
if(check(s)) cout <<"YES\n";
else cout << "NO\n";
}
return 0;
}
유의할 점
- 짝짓기 -> stack
- boolean으로 함수 리턴값 제시하면 조건 o,x 체크 확인할때 편리하다.
- stack을 테스트케이스마다 새로 만들어야한다면 지역변수로 만들기
'알고리즘 > 알고리즘 문제풀이' 카테고리의 다른 글
2636번: 치즈 [C++] (0) | 2023.02.07 |
---|---|
14502번: 연구소 [C++] (0) | 2023.02.07 |
4949번: 균형잡힌 세상 [C++] (0) | 2023.02.05 |
1436번: 영화감독 숌 [C++] (0) | 2023.02.05 |
2852번 : NBA 농구 [C++] (2) | 2023.02.02 |