일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- level3
- BOJ
- binary search
- 프로그래머스
- 3D RPG
- stack
- 프로세스 상태
- Bronze
- 8-Puzzle
- Euclidean
- knapsack Problem
- Gold
- programmers
- two pointer
- effective C++
- Silver
- algorithm
- solid 원칙
- dirtyflag pattern
- Unity
- trie
- LEVEL2
- BFS
- Flyweight Pattern
- level1
- Zenject
- Project
- Modern C++
- PrefixSum
- SWEA
Archives
- Today
- Total
Patrick's Devlog
[BOJ/C++] 덱(10866번) 본문
1. 개요
https://www.acmicpc.net/problem/10866
1-1. 설명
정수를 저장하는 덱을 구현한 다음, 입력으로 주어지는 명령을 처리하는 프로그램을 작성한다. 자세한 설명은 위의 링크를 참조한다.
1-2. 제한 사항
- 첫 줄에 주어지는 명령의 수 N이 주어지며, 1 이상 10,000이하 자연수
- 둘째 줄부터 N 줄까지는 명령이 하나씩 주어지며, 주어지는 정수는 1 이상 100,000 이하 자연수
2. 구현
2-1. 풀이
큐와 스택과 동일하게 메모리 풀을 이용해 구현하였다.
2-2. 코드
#include <iostream>
#include <algorithm>
using namespace std;
constexpr size_t MAX_NUM = 10000;
int dequeue[MAX_NUM];
int main()
{
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
int N, num, rear = 0, front = 0;
string commend;
cin >> N;
for (int i = 0; i < N; i++) {
cin >> commend;
if (commend == "push_front") {
cin >> num;
for (int j = rear; j > 0; j--) {
dequeue[j + 1] = dequeue[j];
}
dequeue[front + 1] = num;
rear += 1;
}
else if (commend == "push_back") {
cin >> num;
dequeue[++rear] = num;
}
else if (commend == "pop_front") {
if (rear == front) cout << "-1\n";
else {
cout << dequeue[front + 1] << "\n";
front += 1;
}
}
else if (commend == "pop_back") {
if (rear == front) cout << "-1\n";
else {
cout << dequeue[rear--] << "\n";
}
}
else if (commend == "size") {
cout << rear - front << "\n";
}
else if (commend == "empty") {
if (rear == front) cout << "1\n";
else cout << "0\n";
}
else if (commend == "front") {
if (rear == front) cout << "-1\n";
else {
cout << dequeue[front + 1] << "\n";
}
}
else if (commend == "back") {
if (rear == front) cout << "-1\n";
else {
cout << dequeue[rear] << "\n";
}
}
}
return 0;
}
'Algorithm > Algorithms Practice' 카테고리의 다른 글
[BOJ/C++] 좌표 정렬하기(11650번) (0) | 2022.09.08 |
---|---|
[BOJ/C++] 단어 정렬(1181번) (0) | 2022.09.07 |
[BOJ/C++] 큐(10845번) (0) | 2022.09.02 |
[BOJ/C++] 스택(10828번) (0) | 2022.09.02 |
[BOJ/C++] 숫자 카드(10815번) (0) | 2022.09.01 |