알고리즘/알고리즘 문제 풀이

(C++) 백준 10845번 - 큐

용꿀 2023. 3. 21. 13:17

문제 링크 : https://www.acmicpc.net/problem/10845

 

10845번: 큐

첫째 줄에 주어지는 명령의 수 N (1 ≤ N ≤ 10,000)이 주어진다. 둘째 줄부터 N개의 줄에는 명령이 하나씩 주어진다. 주어지는 정수는 1보다 크거나 같고, 100,000보다 작거나 같다. 문제에 나와있지

www.acmicpc.net

풀이

이전에 Python을 사용해서 풀어보았던 문제이기에 어려움 없이 풀 수 있었다.

STL Queue를 사용하여 풀어서 실버 4문제치곤 정말 쉬운 문제라고 할 수 있다.

#include <iostream>
#include <queue>

using namespace std;

queue<int> Q;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);    

    int n;
    cin >> n;
    while(n--){
        string s;
        cin >> s;
        if(s == "push"){
            int i;
            cin >> i;
            Q.push(i);
        }else if (s == "front"){
            if(Q.empty()) cout << -1 << "\n";
            else cout << Q.front() << "\n";
        }else if (s == "back"){
            if(Q.empty()) cout << -1 << "\n";
            else cout << Q.back() << "\n";
        }else if (s == "size"){
            cout << Q.size() << "\n";
        }else if (s == "empty"){
            cout << Q.empty() << "\n";
        }else{
            if(Q.empty()){
                cout << -1 << "\n";
            }else{
                cout << Q.front() << "\n";
                Q.pop();
            } 
        }
    }
}