🤍 전 강의 25% 할인 중 🤍

2024년 상반기를 돌아보고 하반기에도 함께 성장해요!
인프런이 준비한 25% 할인 받으러 가기 >>

  • 카테고리

    질문 & 답변
  • 세부 분야

    취업 · 이직

  • 해결 여부

    미해결

Circular Queue에 대해서 질문드려요

22.09.04 22:50 작성 조회수 191

1

Circular Queue의 경우

만약에

[1] [2] [3] [4] [5] [6] 에서

dequeue가 두번 발생해서 앞의 두개가 빈 공간이 되고

[] [] [3] [4] [5] [6]

이때 enqueue가 실행되면 빈 공간을 재 활용 한다고 하셨는데

[7] [8] [3] [4] [5] [6]

array기반이라면, Linked List처럼 다음을 가리키는 정보가 없을것 같은데

6 다음에 7인지 어떻게 알 수가 있을까요?

또 front가 7인지 3인지 구별을 내부적으로 어떻게 할 수 있나요?

 

 

 

답변 1

답변을 작성해보세요.

0

안녕하세요. Taeyoun Kim

image

image

위 그림에서 보듯이 front와 rear는 enqueue와 dequeue가 될 때마다 이동합니다. 코드로 보면 더 이해하기 쉬울 거에요!

https://www.geeksforgeeks.org/circular-queue-set-1-introduction-array-implementation/

해당 코드를 참고해보세요!

 

배열을 기반으로 circular queue를 만들지만, class를 통해 구현하기 때문에, front와 rear변수를 선언해서 해당 index를 가리키게끔 구현할 수 있습니다.

 

혹시 설명이 부족했다면 다시 질문해주세요~!

 

채널톡 아이콘