[문제]
https://www.acmicpc.net/problem/5430
[풀이]
덱 활용 문제이다.
제한 시간이 1초인 것을 유의하자.
처음 시도때는, 덱을 두개 생성하여 R을 입력할때마다 뒤집은 덱을 또 다른 덱에 넣는 방식으로 구현하였는데, 시간 초과가 났다.
R이 짝수번 나온경우 D를 할시 맨 앞의 원소를 삭제하면 되고, R이 홀수번 나온 경우 D를 할시 맨 뒤의 원소를 삭제하면 된다. 출력시에는 R이 짝수일때 그대로 출력, 홀수 일때는 뒤에서 부터 출력한다.
[코드]
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(0);
cin.tie(0);
int n;
cin >> n;
while(n--){
deque <string> q;
int tmp = 0;
string s;
cin >> s;
int n;
cin >> n;
string a;
cin >> a;
string t;
for(int i=0; i<a.size(); i++){
if(a[i] != '[' && a[i] != ',' && a[i] != ']'){
t += a[i];
}
else {
if(!t.empty()) {
q.push_back(t);
t = "";
}
}
}
int rcnt = 0;
for(char &c : s){
if(c == 'R'){
rcnt++;
}
else if(c == 'D'){
if(q.empty()) {
cout << "error" << "\n";
tmp = 1;
break;
}
else {
if(rcnt % 2 == 1)
q.pop_back();
else
q.pop_front();
}
}
}
if(tmp != 1) {
int size = q.size();
for(int i=-1; i<=size; i++){
if(i == -1) cout << '[';
else if(i == size) cout << ']' << '\n';
else if(i == size-1) {
if(rcnt % 2 == 0)
cout << q.front();
else
cout << q.back();
}
else{
if(rcnt % 2 == 0){
cout << q.front() << ',';
q.pop_front();
}
else {
cout << q.back() << ',';
q.pop_back();
}
}
}
}
}
}
'✏️ Algorithm > 알고리즘 풀이' 카테고리의 다른 글
2504번 괄호의 값 - C++ (0) | 2022.07.27 |
---|---|
1926번 그림 - C++ (0) | 2022.07.27 |
1021번 회전하는 큐 - C++ (0) | 2022.07.26 |
2164번 카드2 - C++ (0) | 2022.07.25 |
18258번 큐 2 - C++ (0) | 2022.07.25 |