티스토리 뷰
큐의 연산 - 큐의 생성
변수 rear의 초기값은 큐의 공백 상태를 나타내는 ‘–1’로 시작함
1 2 3 4 5 | #define QUEUE_SIZE 5 typedef int element; element queue[QUEUE_SIZE]; int front = -1; int rear = -1; | cs |
큐의 연산 - 큐의 초기 상태
front ↓ | rear ↓ | |||||
[0] | [1] | [2] | [3] | [4] | ||
queue | 100 | 200 | 300 |
큐의 연산 - 큐의 삽입 연산
삽입 연산이 발생하면 rear 변수만 오른쪽으로 이동하고, 삭제 연산이 발생하면 front 변수만 오른쪽으로 이동함
1 2 3 4 5 6 7 8 9 | void Add_q(int *rear, element item) { if (*rear == QUEUE_SIZE-1) { printf(“Queue is full !!”); return; } queue[++(*rear)] = item; return; } | cs |
data:image/s3,"s3://crabby-images/ac470/ac470f6a842b0345d8c26422659d0021fde55b0e" alt=""
data:image/s3,"s3://crabby-images/1fde9/1fde9092d2394251d2697bc57fb51f69d01565ad" alt=""
큐의 연산 - 큐의 삭제 연산
삭제 연산의 수행 결과로 삭제된 원소를 Delete_q 연산자의 호출 프로그램에게 반환해 줌
1 2 3 4 5 6 7 8 | element Delete_q(int *front, int rear) { if (*front == rear) { printf("Queue is empty\n"); return; } return ( queue[++(*front)] ); } | cs |
큐의 연산 - 큐의 삽입 / 삭제 연산
data:image/s3,"s3://crabby-images/821a2/821a2e9cf9f4c77b05c185ca3cf37608f7fb7455" alt=""
data:image/s3,"s3://crabby-images/c5704/c5704495ce912189f39aa8ec5f60162536e68a2a" alt=""