ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [백준, 큐 스택] 풍선 터뜨리기 2346 C++
    Computer Science/백준 Boj 2023. 10. 21. 23:44


    지문해석

    풍선의 구조

    첫번째 풍선을 터뜨리고 종이에 써져있는 수만큼 이동해서 다음 풍선을 터뜨린다.

    이 때 써져있는 종이의 수가 양수이면 오른쪽 이동, 음수이면 왼쪽으로 이동한다.

    단 ! 0 일 때 왼쪽으로 이동하면 N으로 이동해서 왼쪽으로 이동한다. N 일 때 오른쪽으로 이동하면 0으로 이동해서 오른쪽으로 이동한다.


    풀이

     

    예제 1번을 보자

     

    첫번째 풍선을 터뜨린다.

    종이에 써져있는 3만큼 오른쪽으로 이동한다. 구현 방법은 deque 가장 앞에 있는 원소를 가장 뒤로 붙이면 된다.

     

    가장 앞에 있는 4번째 풍선을 제거한다.

     

    종이에 써져있는 -3만큼 왼쪽으로 이동한다. 구현 방법은 deque 가장 뒤에 있는 원소를 가장 앞으로 붙이면 된다.

    가장 뒤에 있는 5번째 풍선을 제거한다.

     

    위와 같은 순서를 반복하면 아래와 같이 풍선이 남게 되고 3번째 풍선이 제거되고 2번째 풍선이 제거된다.


    코드

    #include <deque>
    #include <iostream>
    #include <cmath>
    
    using namespace std;
    
    int main()
    {
        deque<pair<int, int>> deq;
        int N;
        cin >> N;
        
        int data = 0;
        for(int i = 0; i < N; ++i)
        {
            cin >> data;
            deq.push_back({i + 1, data});
        }
        
        pair<int, int> M = deq.front();
        deq.pop_front();
        
        cout << M.first << " ";
        
        while(deq.size() > 0)
        {
            if(M.second > 0)
            {
                for(int i = 0; i < abs(M.second) - 1; ++i)
                {
                    pair<int, int> front = deq.front();
                    deq.pop_front();
                    deq.push_back(front);
                }
                
                M = deq.front();
                cout << deq.front().first << " ";
                deq.pop_front();
                
            }else if(M.second < 0)
            {
                for(int i = 0; i < abs(M.second) - 1; ++i)
                {
                    pair<int, int> back = deq.back();
                    deq.pop_back();
                    deq.push_front(back);
                }
                M = deq.back();
                cout << deq.back().first << " ";
                deq.pop_back();
            }
        }
        return 0;
    }

    'Computer Science > 백준 Boj' 카테고리의 다른 글

    [백준 조합] 다리놓기 1010 C++  (0) 2023.10.23
    [백준 조합] 1010 C++  (0) 2023.10.23
    [백준, 큐스텍] 24511 queuestack C++  (1) 2023.10.21
    백준 1238 파티 C++  (0) 2023.10.20
    백준 1202 보석 도둑  (0) 2023.10.19
Designed by Tistory.