BOJ - 5430 - AC

ggh·2022년 5월 11일
0

백준

목록 보기
24/112

BOJ - 5430 - AC

문제


5430번: AC

https://user-images.githubusercontent.com/71277820/166416767-cafdbe5b-9c7a-4ebc-83af-a34815e983bf.png

문제 개념


문제

선영이는 주말에 할 일이 없어서 새로운 언어 AC를 만들었다. AC는 정수 배열에 연산을 하기 위해 만든 언어이다. 이 언어에는 두 가지 함수 R(뒤집기)과 D(버리기)가 있다.

함수 R은 배열에 있는 수의 순서를 뒤집는 함수이고, D는 첫 번째 수를 버리는 함수이다. 배열이 비어있는데 D를 사용한 경우에는 에러가 발생한다.

함수는 조합해서 한 번에 사용할 수 있다. 예를 들어, "AB"는 A를 수행한 다음에 바로 이어서 B를 수행하는 함수이다. 예를 들어, "RDD"는 배열을 뒤집은 다음 처음 두 수를 버리는 함수이다.

배열의 초기값과 수행할 함수가 주어졌을 때, 최종 결과를 구하는 프로그램을 작성하시오.

입력

첫째 줄에 테스트 케이스의 개수 T가 주어진다. T는 최대 100이다.

각 테스트 케이스의 첫째 줄에는 수행할 함수 p가 주어진다. p의 길이는 1보다 크거나 같고, 100,000보다 작거나 같다.

다음 줄에는 배열에 들어있는 수의 개수 n이 주어진다. (0 ≤ n ≤ 100,000)

다음 줄에는 [x1,...,xn]과 같은 형태로 배열에 들어있는 정수가 주어진다. (1 ≤ xi ≤ 100)

전체 테스트 케이스에 주어지는 p의 길이의 합과 n의 합은 70만을 넘지 않는다.

출력

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

구현


#include <iostream>
#include <string>
#include <deque>
using namespace std; 
/* 
test case num 
order 
test resource
*/
int main()
{
    ios_base :: sync_with_stdio(false); 
    cin.tie(NULL); 
    cout.tie(NULL);

    int num;
    cin >> num;

    deque<string> answer;
    for(int i=0; i < num; i++)
    {
        string OrderList;
        string tmp="";
        int N;
        deque<int> L;
        string gb;
        cin >> OrderList >> N >> gb;
        // 리스트 추출
        // [1,2,3,4] -> 1 2 3 4
        for(int j=1; j < gb.size()-1; j++)
        {
            if(gb[j] != ',')
            {
                if(gb[j+1] == ']')
                {
                    tmp += gb[j];
                    L.push_back(stoi(tmp));
                }
                else  
                    tmp += gb[j];
            }
            else
                if(tmp != "")
                {
                    L.push_back(stoi(tmp));
                    tmp = "";
                }
        }
        // 명령어 처리 
        // 매번마다 reverse를 해주면 시간초과가 발생하기에
        // 덱의 특성을 이용한다. 
        int R_count = 0;
        bool err = false;
        for(auto &el : OrderList)
        {
            if(!L.empty() && el == 'R')
                R_count++;  
            else if(!L.empty() && el == 'D')
            {
                if(R_count%2 == 0)
                    L.pop_front();
                else
                    L.pop_back();
            }
            // 에러가 발생하는 경우 
            else if(L.empty() && el == 'D')
            {
                err = true;
                answer.push_back("error");
                break;
            }
        }
        if(!L.empty())
        {
            string temp = "[";
            if(R_count%2 == 0)
            {
                while(!L.empty())
                {
                    temp += to_string(L.front()) + ","; 
                    L.pop_front();
                }
                temp.pop_back();
                temp += "]";
                answer.push_back(temp);
            }
            else
            {
                while(!L.empty())
                {
                    temp += to_string(L.back()) + ","; 
                    L.pop_back();
                }

                temp.pop_back();
                temp += "]";
                answer.push_back(temp);
            }
        }
        else if(L.empty() && err == false)
            answer.push_back("[]");
        else
            continue;
    }
    while(!answer.empty())
    {
        cout << answer.front() << '\n';
        answer.pop_front();
    }
    return 0;
}

SOL


  • 명령어 처리
    • R 수행시 reverse를 매번 해줄 시 시간초과가 발생하기 때문에 덱의 특성을 이용하여 해결한다.
    • D 수행시 또한 R의 홀짝에 따라 처리를 해주어 해결한다.
      • 짝 pop_front
      • 홀 pop_back

Reference & 다른 PS 모음집


https://github.com/ggh-png/PS

C++ STL 프로그래밍: 덱(deque)

profile
See you in a minute. : )

0개의 댓글