매일 조금씩

백준 18258번: 큐 2 본문

알고리즘

백준 18258번: 큐 2

mezo 2020. 4. 7. 15:25
728x90
반응형

 

큐의 명령어를 익히는 간단한 문제이다.

 

 

 

 

 

 

 

 

 

#include <iostream>
#include <string>
#include <stack>
#include <queue>
using namespace std;

int n;


int main(void) {
	ios_base::sync_with_stdio(0);
	cin.tie(0);	//cin 실행속도 향상

	string q;
	queue<int> que;

	cin >> n;
	for (int i = 0; i < n; i++) {
		cin >> q;
		if (q == "push") {
			int p = 0;
			cin >> p;
			que.push(p);
		}
		else if (q == "pop")
			if (que.empty())
				cout << "-1\n";
			else {
				cout << que.front() << "\n";
				que.pop();
			}

		else if (q == "size")
			cout << que.size() << "\n";
		else if (q == "empty")
			cout << que.empty() << "\n";
		else if (q == "front")
			if (que.empty())
				cout << "-1\n";
			else
				cout << que.front() << "\n";

		else if (q == "back")
			if (que.empty())
				cout << "-1\n";
			else
				cout << que.back() << "\n";
			
	}

	return 0;
}
728x90
반응형

'알고리즘' 카테고리의 다른 글

백준 11866번: 요세푸스 문제 0  (0) 2020.04.07
백준 2164번: 카드 2  (0) 2020.04.07
백준 1874번: 스택 수열  (0) 2020.04.05
백준 4949번: 균형잡힌 세상  (0) 2020.04.05
백준 9012번: 괄호  (0) 2020.04.05