오봉이와 함께하는 개발 블로그
자료구조 데크(deQue) 본문
728x90
데크(deQue : double endedQueue)
- 삽입과 삭제가 양끝에서 이루어지는 구조
- 스택과 큐를 하나의 선형 리스트 구조에 복합시킨 형태
- end1과 end2 포인터 사용
- 양쪽 끝에서의 오버플로우의 가능성을 줄이기 위해 데크 내의 중심 근처에부터 저장 가능
데크 예제
- DequeArray.java
package AlgoPractice.deque;
import java.util.ArrayDeque;
import java.util.Deque;
public class DequeArray {
public static void main(String[] args) {
Deque<String> deque = new ArrayDeque<String >();
System.out.println("데이터 3개 삽입");
deque.add("사과");
System.out.println(deque);
deque.add("딸기");
System.out.println(deque);
deque.add("망고");
System.out.println(deque);
deque.offer("수박");
System.out.println(deque); // [사과, 딸기, 망고, 수박]
System.out.println();
System.out.println("앞쪽에 삽입");
deque.addFirst("배");
System.out.println(deque); // [배, 사과, 딸기, 망고, 수박]
System.out.println();
System.out.println("그냥 삽입");
deque.add("용과");
System.out.println(deque); // [배, 사과, 딸기, 망고, 수박, 용과]
System.out.println();
System.out.println("뒤쪽에 삽입");
deque.addLast("용과"); // add랑 비슷하게 들어감 / 똑같은 값 삽입 가능
System.out.println(deque); // [배, 사과, 딸기, 망고, 수박, 용과, 포도]
System.out.println();
System.out.println("peek 수행 : " + deque.peek());
System.out.println("deQue 사이즈 : " + deque.size());
System.out.println();
System.out.println("순회");
for (String item : deque) {
System.out.print(item + " ");
}
System.out.println();
System.out.println();
System.out.println("데이터 꺼내기");
System.out.println("remove : " + deque.remove());
System.out.println(deque);
System.out.println();
System.out.println("찾아서 삭제");
System.out.println("사과 remove : " + deque.remove("사과")); // true
System.out.println(deque);
System.out.println();
System.out.println("찾아서 삭제");
System.out.println("코코넛 remove : " + deque.remove("코코넛")); // false
System.out.println(deque);
System.out.println();
System.out.println("앞쪽에 삽입");
deque.addFirst("용과");
System.out.println(deque);
System.out.println();
System.out.println("찾아서 삭제");
System.out.println("용과 remove : " + deque.remove("용과")); // true
System.out.println(deque);
// [용과, 딸기, 망고, 수박, 용과, 용과] -> [딸기, 망고, 수박, 용과, 용과]
System.out.println();
System.out.println("remove All : " + deque.removeAll(deque)); // 전체 삭제
System.out.println(deque);
System.out.println();
System.out.println("데이터 3개 삽입");
deque.add("사과");
System.out.println(deque);
deque.add("딸기");
System.out.println(deque);
deque.add("망고");
System.out.println(deque);
deque.offer("수박");
System.out.println(deque); // [사과, 딸기, 망고, 수박]
System.out.println();
System.out.println("poll : " + deque.poll()); // 맨 앞에 있는 값 삭제
System.out.println(deque); // [딸기, 망고, 수박]
System.out.println();
System.out.println("pollFirst : " + deque.pollFirst());
System.out.println(deque); // [망고, 수박]
System.out.println();
System.out.println("pollLast : " + deque.pollLast());
System.out.println(deque); // [망고]
// deQue를 Stack처럼 사용
System.out.println();
System.out.println("push 수행");
deque.push("밤"); // addFirst와 동일
deque.push("밤");
System.out.println(deque);
System.out.println();
System.out.println("pop 수행 : " + deque.pop()); // 맨 앞 삭제
System.out.println(deque);
}
}
728x90
'알고리즘 & 자료구조 & 네트워크' 카테고리의 다른 글
연결 리스트 - 단일 연결 리스트 (0) | 2021.11.29 |
---|---|
연결 리스트 - 선형 리스트 (0) | 2021.11.29 |
자료구조 큐(Queue) (0) | 2021.11.29 |
자료구조와 스택 (0) | 2021.11.29 |
동적 프로그래밍 기법 (0) | 2021.11.29 |
Comments