[자료구조] 덱 (Deque)

zerokick·2023년 4월 22일
0

Data Structure

목록 보기
13/14
post-thumbnail

덱 (Deque)


덱이란?

Double Ended Queue, 양쪽 끝에서 삽입과 삭제가 가능하다.

덱의 특징

  1. 원소의 추가가 O(1)
  2. 원소의 제거가 O(1)
  3. 제일 앞/뒤의 원소 확인이 O(1)
  4. 제일 앞/뒤가 아닌 나머지 원소들의 검색/변경은 원칙적으로 불가하다.

덱의 구현

import java.io.*;
import java.sql.Array;
import java.util.ArrayDeque;
import java.util.LinkedList;
import java.util.List;
import java.util.StringTokenizer;

public class BOJ10866 {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
        StringTokenizer st;

        int n = Integer.parseInt(br.readLine());

        ArrayDeque<Integer> dq = new ArrayDeque<Integer>();

        for (int i = 0; i < n; i++) {
            st = new StringTokenizer(br.readLine());
            switch (st.nextToken()) {
                case "push_front":
                    dq.offerFirst(Integer.parseInt(st.nextToken()));
                    break;
                case "push_back":
                    dq.offerLast(Integer.parseInt((st.nextToken())));
                    break;
                case "pop_front":
                    if(dq.isEmpty()) bw.write(String.valueOf(-1) + "\n");
                    else bw.write(String.valueOf(dq.pollFirst()) + "\n");
                    break;
                case "pop_back":
                    if(dq.isEmpty()) bw.write(String.valueOf(-1) + "\n");
                    else bw.write(String.valueOf(dq.pollLast()) + "\n");
                    break;
                case "size":
                    bw.write(String.valueOf(dq.size()) + "\n");
                    break;
                case "empty":
                    if(dq.isEmpty()) bw.write(String.valueOf(1) + "\n");
                    else bw.write(String.valueOf(0) + "\n");
                    break;
                case "front":
                    if(dq.isEmpty()) bw.write(String.valueOf(-1) + "\n");
                    else bw.write(String.valueOf(dq.peekFirst()) + "\n");
                    break;
                case "back":
                    if(dq.isEmpty()) bw.write(String.valueOf(-1)+ "\n");
                    else bw.write(String.valueOf(dq.peekLast()) + "\n");
                    break;
            }
        }

        br.close();
        bw.flush();
        bw.close();
    }
}
profile
Opportunities are never lost. The other fellow takes those you miss.

0개의 댓글