티스토리 뷰
1. 큐 자료구조 개념 설명
큐(Queue)는 가장 간단한 자료구조 중 하나로 FIFO(First In First Out)의 특성을 가지고 있습니다.
FIFO는 큐에 먼저 들어온 데이터가 먼저 나간다는 의미이고,
은행이나 맛집에서 방문한 순서대로 입장하는 평범한 대기열을 생각하면 쉽게 이해할 수 있습니다.
큐의 가장 끝 자리(rear)에 데이터를 넣는 것을 enqueue라고 하고,
가장 앞 자리(front)에서 데이터를 빼는 것을 dequeue라고 합니다.
dequeue 시 가장 먼저 들어온 데이터에 가장 높은 우선순위를 두고 뺀다면 일반적인 큐가 됩니다.
하지만 dequeue 시 큐에 들어온 순서가 아닌 최소값, 최대값 등 특별한 우선순위를 두고 빼는 방식을 쓴다면
이는 우선순위 큐(Priority Queue)라고 하고 통상 힙(Heap)으로 구현합니다.
힙에 대한 내용은 아래 링크 참고하시길 바랍니다.
https://rightbellboy.tistory.com/342
2. 큐 자료구조 동작 원리
유연한 방식으로 구현하려면 Linked List를 기반으로 Head와 Tail을 포인터로 두고 구현하는 것이 맞겠지만
통상적으로 max 크기를 특정할 수 있는 알고리즘 시험에 맞추어 1차원 배열로 설명하겠습니다.
우선 큐에 저장할 Data를 담을 1차원 배열을 선언하고, fr(front), re(rear)라는 두 integer 변수를 선언합니다.
이 두 변수들은 배열의 처음과 끝의 인덱스를 기억하게 하고 초기 값은 둘 다 0으로 설정합니다.
이 상태에서 큐에 3이라는 값이 들어오면, re(index 0)에 값을 넣고 re를 1 증가시킵니다.
(가장 뒤에 넣고, 가장 앞에서 빼는 형태라고 보시면 됩니다)
여기에 7이라는 값을 다시 넣는다고 하면, 마찬가지로 re(index 1)에 해당 값을 넣고 re를 1 증가시킵니다.
이번엔 dequeue를 해보고 어떻게 동작하는지 보겠습니다.
FIFO의 특성을 가지는 queue의 성질에 따라 먼저 들어간 3이 나와야 합니다.
따라서 fr(index 0)에 있는 값 3을 빼고 fr을 1 증가시킵니다.
위 이미지에서는 3이 지워진 것처럼 표기했지만,
fr이 증가되어 index 0에는 접근할 수 없으므로 해당 값은 그대로 두어도 됩니다.
이어서 추가로 dequeue를 하면 아래와 같이 7이 나가게 됩니다.
처음 상태와 마지막 상태를 살펴보면, fr과 re가 같으면 queue가 비어있다고 볼 수 있습니다.
이를 활용하여 queue가 빌 때까지 반복하는 조건으로 사용하거나( while (fr < re) ),
queue가 비어있는지를 확인하는 함수도 구현할 수 있습니다.( return fr >= re; )
자세한 내용은 아래 코드를 보면서 학습해보시길 바랍니다.
3. 큐 자료구조 구현 예시 코드
#include <cstdio>
struct _que {
int arr[7], fr, re;
void init() {
fr = re = 0;
}
void enqueue(int v) {
arr[re++] = v;
}
int dequeue() {
return arr[fr++];
}
bool isEmpty() {
return fr >= re;
}
} QUE;
int main() {
QUE.init();
QUE.enqueue(3);
QUE.enqueue(7);
printf("queue is empty ? %s\n", QUE.isEmpty() ? "true" : "false");
printf("%d has been dequeued\n", QUE.dequeue());
printf("%d has been dequeued\n", QUE.dequeue());
printf("queue is empty ? %s\n", QUE.isEmpty() ? "true" : "false");
return 0;
}
'개발자 > 자료구조, 알고리즘 (C언어)' 카테고리의 다른 글
힙 자료구조 개념 설명 및 예시 코드 (1 base) (C/C++) (0) | 2024.09.22 |
---|
- Total
- Today
- Yesterday
- 유연함의힘
- 동탄에듀센터
- JUNGOL
- 쿠프마케팅
- 독서 감상평
- 여가포인트
- 인간본성불패의법칙
- 나는늘잘해야한다고생각한다
- 문현공
- 정올
- 정세현의통찰
- 영화감상평
- 안전운전특약
- AdSendse
- 독서감상평
- 당신도느리게나이들수있습니다
- 관계가상처가되기전에
- 세상을 읽는 새로운 언어 빅데이터
- 동탄에듀센터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 |