인프런 커뮤니티 질문&답변

Taeyoun Kim님의 프로필 이미지
Taeyoun Kim

작성한 질문수

기출로 대비하는 개발자 전공면접 [CS 완전정복]

Q. Queue는 어떤 자료구조 인가요? (외 1문제)

Circular Queue에 대해서 질문드려요

작성

·

234

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를 가리키게끔 구현할 수 있습니다.

 

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

 

Taeyoun Kim님의 프로필 이미지
Taeyoun Kim

작성한 질문수

질문하기