[#65][알고리즘] 프린터 큐(우선순위 큐, Priority Queue)

백준 > 프린터 큐

문제 링크(https://www.acmicpc.net/problem/1966)

문제

여러분도 알다시피 여러분의 프린터 기기는 여러분이 인쇄하고자 하는 문서를 인쇄 명령을 받은 ‘순서대로’, 즉 먼저 요청된 것을 먼저 인쇄한다. 여러 개의 문서가 쌓인다면 Queue 자료구조에 쌓여서 FIFO - First In First Out - 에 따라 인쇄가 되게 된다. 하지만 상근이는 새로운 프린터기 내부 소프트웨어를 개발하였는데, 이 프린터기는 다음과 같은 조건에 따라 인쇄를 하게 된다.
  1. 현재 Queue의 가장 앞에 있는 문서의 ‘중요도’를 확인한다.
  2. 나머지 문서들 중 현재 문서보다 중요도가 높은 문서가 하나라도 있다면, 이 문서를 인쇄하지 않고 Queue의 가장 뒤에 재배치 한다. 그렇지 않다면 바로 인쇄를 한다.
예를 들어 Queue에 4개의 문서(A B C D)가 있고, 중요도가 2 1 4 3 라면 C를 인쇄하고, 다음으로 D를 인쇄하고 A, B를 인쇄하게 된다.
여러분이 할 일은, 현재 Queue에 있는 문서의 수와 중요도가 주어졌을 때, 어떤 한 문서가 몇 번째로 인쇄되는지 알아내는 것이다. 예를 들어 위의 예에서 C문서는 1번째로, A문서는 3번째로 인쇄되게 된다.

입력

첫 줄에 test case의 수가 주어진다. 각 test case에 대해서 문서의 수 N(100이하)와 몇 번째로 인쇄되었는지 궁금한 문서가 현재 Queue의 어떤 위치에 있는지를 알려주는 M(0이상 N미만)이 주어진다. 다음줄에 N개 문서의 중요도가 주어지는데, 중요도는 적절한 범위의 int형으로 주어진다. 중요도가 같은 문서가 여러 개 있을 수도 있다. 위의 예는 N=4, M=0(A문서가 궁금하다면), 중요도는 2 1 4 3이 된다.

출력

각 test case에 대해 문서가 몇 번째로 인쇄되는지 출력한다.

예제 입력 

3
1 0
5
4 2
1 2 3 4
6 0
1 1 9 1 1 1

예제 출력 

1
2
5
C++풀이
#include <iostream>
#include <queue>
using namespace std;
 
int main() {
    int test, a, b, x, r;
    
    cin >> test;
    cin.ignore();
    for (int i = 0; i < test;i++) {
        priority_queue<int> que;
        queue<pair<intint>> q;
        cin >> a >> b;
    
        r = 0;
        for (int j = 0; j < a; j++) {
            cin >> x;
            que.push(x);    //입력된 순위
            q.push({ j,x});
        }
 
        while (!q.empty()) {
            int index = q.front().first;    //인덱스
            int num = q.front().second;        //입력된 순위
            q.pop();
            if (que.top() == num) {
                //일치하면 pop
                r++;
                que.pop();
                if (index == b) {
                    cout << r << endl;
                    break;
                }
            }
            else {
                //일치하지 않으면 뒤로
                q.push({ index,num });
            }
        }
    }
    
    return 0;
}
cs

예) a = 4, b = 3
    우선순위 2 1 4 3 일 때

for문으로 입력 모두 받은 후
q의 상태 (3,3) (2,4) (1,1) (0,2)

index = 0
num = 2

q.pop() 후 => (3,3) (2,4) (1,1)
que.top() = 4, num = 2 : 일치하지 않음. 큐에 다시 입력
q의 상태 (0,2) (3,3) (2,4) (1,1)

index = 1
num = 1

q.pop() 후 => (0,2) (3,3) (2,4)
que.top() = 4, num = 1 : 일치하지 않음. 큐에 다시 입력
q의 상태 (1,1) (0,2) (3,3) (2,4)

index = 2
num = 4

q.pop() 후 => (1,1) (0,2) (3,3)
que.top() = 4, num = 4 : 일치함
r++ : r = 1
que.pop()
index = 2, b = 3 일치하지 않음

index = 3
num = 3

q.pop() 후 => (1,1) (0,2)
que.top() = 3, num = 3 : 일치함
r++ : r = 2
que.pop()
index = 3, b = 3 일치함
=> r을 출력 후 break

답 : 2

댓글

가장 많이 본 글