관리 메뉴

민우의 코딩노트

5430번 AC - C++ 본문

Algorithm/BOJ

5430번 AC - C++

미미누 2022. 7. 26. 16:00

[문제]
https://www.acmicpc.net/problem/5430

5430번: AC

각 테스트 케이스에 대해서, 입력으로 주어진 정수 배열에 함수를 수행한 결과를 출력한다. 만약, 에러가 발생한 경우에는 error를 출력한다.

www.acmicpc.net


[풀이]
덱 활용 문제이다.
제한 시간이 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 > BOJ' 카테고리의 다른 글

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