티스토리 뷰

Algorithm/BOJ

[C/C++] 백준 28278번

poopooreum 2024. 3. 2. 09:43
반응형

✏️ 문제 링크

https://www.acmicpc.net/problem/28278

 

28278번: 스택 2

첫째 줄에 명령의 수 N이 주어진다. (1 ≤ N ≤ 1,000,000) 둘째 줄부터 N개 줄에 명령이 하나씩 주어진다. 출력을 요구하는 명령은 하나 이상 주어진다.

www.acmicpc.net

 

✏️ 문제 설명

 

✏️ 문제 코드

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

int main() {

	ios::sync_with_stdio(false);
	cin.tie(NULL);
	cout.tie(NULL);

	int N;
	cin >> N;

	stack<int>myStack;

	for (int i = 0; i < N; i++) {
		
		int order;
		cin >> order;

		if (order == 1) {
			int x;
			cin >> x;
			myStack.push(x);
		}
		
		else if (order == 2) {
			if (myStack.size() != 0) {
				int a = myStack.top();
				cout << a<<'\n';
				myStack.pop();
			}
			else
				cout << -1 << '\n';
		}
		else if (order == 3) {
			cout << myStack.size()<<"\n";
		}
		else if (order == 4) {
			if (myStack.size() == 0)
				cout << 1 << "\n";
			else
				cout << 0 << '\n';
		}
		else if (order == 5) {
			if (myStack.size() == 0)
				cout << -1 << '\n';
			else
				cout << myStack.top()<<'\n';
		}
	}

}

 

반응형
반응형
공지사항
최근에 올라온 글
최근에 달린 댓글
Total
Today
Yesterday
링크
«   2024/07   »
1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31
글 보관함