deque (double queue)
front, rear가 모두 있는 큐라고 생각하면 된다.
큐를 일반화한 자료 구조로 처음, 끝 모두에서 삽입 및 삭제가 가능하며 스택과 큐의 장점을 지니고 있다.
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 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 | #include <iostream> using namespace std; struct node { int data; node *prev, *next; static node* getNode(int data) { node* new_node = new node(); new_node->data = data; new_node->prev = new_node->next = NULL; return new_node; //새로운 노드 추가 시 새로운 노드의 전과 다음은 null } }; class deque { node* front; node* rear; int size; public: deque() { front = rear = NULL; size = 0; } void insertFront(int data); void insertRear(int data); void delFront(); void delRear(); int getFront(); int getRear(); int getSize(); bool isEmpty(); void erase(); void display(); }; bool deque::isEmpty() { return (front == NULL); } int deque::getSize() { return size; } void deque::insertFront(int data) { node* new_node = node::getNode(data); if (new_node == NULL) { cout << "deque overflow"; } else { cout << "insertFront : " << data; if (front == NULL) { rear = front = new_node; // 비어있으면 다 같다 } else { new_node->next = front; //double이기 때문에 새로운 노드 다음이 프론트 //앞에 추가되는 거니까 front->prev = new_node; // front앞이 뉴노드 front = new_node; // 앞쪽이 뉴노드가 됨 } size++; //사이즈 증가 } cout << endl; } void deque::insertRear(int data) { node* new_node = node::getNode(data); if (new_node == NULL) { cout << "deque overflow"; //new_node가 null이면 꽉 찼다는 것 } else { cout << "insertRear : " << data; if (rear == NULL) { front = rear = new_node; //아무것도 없으니 다 같다 } else { new_node->prev = rear; rear->next = new_node; rear = new_node; } size++; } cout << endl; } void deque::delFront() { if (isEmpty()) { cout << "deque underflow"; } else { //큐에 원소하나라도 있다면 cout << "delFront : " << front->data; node* temp = front; //임시로 프론트 저장 front = front->next; // 프론트가 삭제되기 때문에 프론트는 //기존 프론트 다음이 된다 if (front == NULL) { rear = NULL; //새로운 프론트가 없으면 rear도 NULL } else { front->prev = NULL; //있으면 front 전 노드는 없으므로 NULL } free(temp); size--; //삭제했으므로 크기 줄어듦 } cout << endl; } void deque::delRear() { if (isEmpty()) { cout << "deque underflow"; } else { cout << "delRear : " << rear->data; node* temp = rear; //뒤에서 삭제하니까 rear로 초기화 rear = rear->prev; //새로운 레어는 기존 레어 전 if (rear == NULL) { front = NULL; //끝이 없으면 프론트도 없다(왜냐면 새로운 레어는 기존 레어 전이니까) } else { rear->next = NULL; //레어가 null이 아니면 레어다음은 null 끝이기 때문 } free(temp); size--; //삭제했기 때문에 size 감소 } cout << endl; } int deque::getFront() { if (isEmpty()) { return -1; } else { return front->data; } } int deque::getRear() { if (isEmpty()) { return -1; } else { return rear->data; } } void deque::erase() { //전체삭제 rear = NULL; node* temp = front; while (temp != NULL) { free(temp); temp = temp->next; } size = 0; } void deque::display() { node* temp = front; cout << "deque element : "; while (temp != NULL) { cout << temp->data << " "; temp = temp->next; } cout << endl; } int main() { deque dq; dq.insertFront(-1); dq.insertFront(-2); dq.insertFront(-3); dq.display(); dq.insertRear(1); dq.insertRear(2); dq.insertRear(3); dq.display(); cout << "current front : " << dq.getFront() << " current rear : " << dq.getRear() << endl; dq.delFront(); dq.delRear(); dq.display(); cout << "current front : " << dq.getFront() << " current rear : " << dq.getRear() << endl; return 0; } | cs |
실행 결과
앞쪽에 -1, -2, -3 을 추가했으므로 가장 나중에 들어간 -3이 front다.
뒤쪽에 1, 2, 3을 추가했으므로 가장 나중에 들어간 3이 rear다.
앞쪽, 뒤쪽에서 원소를 하나씩 제거했으므로 남는 원소는 -2, -1, 1, 2
따라서 현재 front는 -2, rear는 2가 된다.
geeksforgeeks를 보고 따라쓰며 주석을 덧붙인 것이다.
queue 전체를 출력하는 display 함수를 출력하고 각 함수에서 원소 출력 위치가 좀 다를 뿐이다.
자세한 내용은 geeksforgeeks 참고
geeksforgeeks deque link (https://www.geeksforgeeks.org/implementation-deque-using-doubly-linked-list/)
'PS' 카테고리의 다른 글
백준 10866번 C++ 덱 구현 (0) | 2019.02.12 |
---|---|
C++ Queue(큐) 배열, 연결 리스트로 구현 (0) | 2019.02.12 |
C++ Stack(스택) 연결 리스트로 구현 (0) | 2019.02.12 |
Linked List C++ (0) | 2019.02.07 |
백준 1932번 C++ 정수 삼각형 (0) | 2019.02.07 |
댓글