Post

Deque (데큐)

1.데크 (Deque)

  • 양쪽에서 삽입과 삭제가 모두 가능한 자료구조
    • Deque : Doubly-ended Queue
    • Stack과 Queue를 합한 형태

2. 데크 기본 구조

  • 데크의 기본구조는 양방향에서 삽입 삭제 가능 구조
  • 일부 기능을 제한하여 용도에 맞게 변형 가능

Untitled

1) 입력제한 데크 (Scroll)

  • 한 쪽의 입력을 제한한 데크

Untitled 1

2) 출력제한 데크 (Shelf)

  • 한 쪽의 출력을 제한한 데크

Untitled 2

(실습 : 데크)

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
32
33
34
35
36
37
38
39
40
// 선형 자료구조 - 데크

import java.util.ArrayDeque;
import java.util.Deque;

public class Main {
    public static void main(String[] args) {
        Deque deque = new ArrayDeque();

        // Front 부분 입력
        deque.addFirst(1);
        deque.addFirst(2);
        deque.addFirst(3);
        System.out.println(deque);

        // Rear 부분 입력
        deque.addLast(10);
        deque.addLast(20);
        deque.addLast(30);
        System.out.println(deque);

        // Front 부분 출력
        System.out.println(deque.removeFirst());
        System.out.println(deque);

        // Rear 부분 출력
        System.out.println(deque.removeLast());
        System.out.println(deque);

        System.out.println(deque.removeLast());
        System.out.println(deque.removeLast());
        System.out.println(deque.removeLast());
        System.out.println(deque.removeLast());
        System.out.println(deque);

        System.out.println(deque.pollLast());
        System.out.println(deque.removeLast()); // deque이 비어있는 상태에서 removeLast를 하면 Exception 발생

    }
}

Untitled 3

This post is licensed under CC BY 4.0 by the author.