06. 큐
큐 개요
- Queue는 뒤쪽으로 들어가서 앞쪽으로 나오는 자료구조
- PUSH(데이터 삽입), POP(데이터 삭제) 등의 연산
큐의 연산 과정 (배열)
data:image/s3,"s3://crabby-images/49038/4903880177e6ba656ec92268f0b1274832337ffe" alt="image.png"
data:image/s3,"s3://crabby-images/1eff9/1eff99a4f4c90866534223566dcb9a1aebf6edfe" alt="image.png"
data:image/s3,"s3://crabby-images/5c1ab/5c1aba40591b6c0d0d25b25cecf4ce9aa38d1480" alt="image.png"
data:image/s3,"s3://crabby-images/5732c/5732cf2468374555000d726bd3bb813f042f1b9b" alt="image.png"
data:image/s3,"s3://crabby-images/0a957/0a957aef01cceba64059b3c880c8aaf3967f8edc" alt="image.png"
data:image/s3,"s3://crabby-images/402e6/402e65385fc01bc242cdb1d5c589ab4324702062" alt="image.png"
data:image/s3,"s3://crabby-images/15494/15494fe95738e4e0d38a7ef0ecafb781585f3402" alt="image.png"
큐의 구현 (배열)
#include <stdio.h>
#define SIZE 10000
#define INF 99999999
int queue[SIZE];
int front = 0;
int rear = 0;
void push(int data) {
if (rear >= SIZE) {
printf("Queue overflow\n");
return;
}
queue[rear++] = data;
}
int pop() {
if (front == rear) {
printf("Queue underflow\n");
return -INF;
}
return queue[front++];
}
void show() {
printf("=== 큐 입구 ===\n");
for (int i = front; i < rear; i++) {
printf("%d\n", queue[i]);
}
printf("=== 큐 출구 ===\n");
}
int main(void) {
push(7);
push(5);
push(4);
pop();
push(6);
pop();
show();
system("pause");
return 0;
}
큐의 연산 과정 - 삽입 (연결 리스트)
data:image/s3,"s3://crabby-images/d7b57/d7b57ff6e039f3c1b21c9b9e46aede081c3bdfe2" alt="image.png"
data:image/s3,"s3://crabby-images/65f37/65f379d0a4fcac4737109c4a3ec7883a5bc67b38" alt="image.png"
data:image/s3,"s3://crabby-images/187a7/187a749817cbeff8fb7d7f8e7621af94411a4f20" alt="image.png"
data:image/s3,"s3://crabby-images/d5968/d5968b7c3c0fdf4264e5fc5dfae99a53ef3a6e05" alt="image.png"
큐의 연산 과정 - 추출 (연결 리스트)
data:image/s3,"s3://crabby-images/636ef/636ef33296be907f5d4d0e7d4642f0ae1c4da0ba" alt="image.png"
data:image/s3,"s3://crabby-images/40b63/40b639acaf62f60a72e34a517628fe89be9af1c0" alt="image.png"
data:image/s3,"s3://crabby-images/8c008/8c00851f5cbc6a91513711acf7c8070c09aa976d" alt="image.png"
큐의 구현 (연결 리스트)
#include <stdio.h>
#include <stdlib.h>
#define INF 99999999
typedef struct {
int data;
struct Node* next;
} Node;
typedef struct {
Node* front;
Node* rear;
int count;
} Queue;
void push(Queue* queue, int data) {
Node* node = (Node*)malloc(sizeof(Node));
node->data = data;
node->next = NULL;
if (queue->count == 0) {
queue->front = node;
}
else {
queue->rear->next = node;
}
queue->rear = node;
queue->count++;
}
int pop(Queue* queue) {
if (queue->count == 0) {
printf("Queue underflow\n");
return -INF;
}
Node* node = queue->front;
int data = node->data;
queue->front = node->next;
free(node);
queue->count--;
return data;
}
void show(Queue* queue) {
Node* cur = queue->front;
printf("=== 큐 입구 ===\n");
while (cur != NULL) {
printf("%d\n", cur->data);
cur = cur->next;
}
printf("=== 큐 출구 ===\n");
}
int main(void) {
Queue queue;
queue.front = queue.rear = NULL;
queue.count = 0;
push(&queue, 7);
push(&queue, 5);
push(&queue, 4);
pop(&queue);
push(&queue, 6);
pop(&queue);
show(&queue);
system("pause");
return 0;
}