inflearn logo
강의

Khóa học

Chia sẻ kiến thức

Trở thành người vượt qua kỳ thi lập trình - Hoàn thành trong 4 tuần

Độ phức tạp thời gian - Phân tích mã nguồn

시간복잡도 개념문제 Deque질문

73

somang567

2 câu hỏi đã được viết

0

[ 질문 배경 ]

Deque에 대한 자료를 보면 포인터를 사용한다고 나와있습니다.

따라서 popleft()시 맨 좌측부터 포인터가 가르키며 삭제하게 되는데, 이는 논리적으로 "삭제"라는 개념보다는 포인터가 가르키는 곳을 다음으로 이동시킨다는 의미를 가진다고 gpt를 통해 알게 되었습니다.

 

[ 질문 ]

  1. 그렇다면, popleft()시 포인터가 다음으로 이동할 시 메모리에 적재되어 있던 이전 값은

그대로 남아있게 될텐데, 그렇다면 이것은 메모리 낭비로 이어질 수 있지 않나요?

 

  1. 자바의 경우 가비지 컬렉터가 알아서 메모리를 관리하죠. GPT에게 물어보니 메모리 슬롯은 유지하며 재사용할 수 있도록 대기상태에 들어간다고 합니다.

     

    그렇다면 이 재사용을 할지 말지에 대한 것은 누가 결정하며 어떻게 처리되나요? 궁금합니다.

     


    C의 경우 malloc 으로 메모리 빌림 , 메모리 반납을 거치게 되는데, 이 경우도 궁금합니다.

python 알고리즘 data-structure 북-챌린지

Câu trả lời 1

0

dremdeveloper

deque는 하나의 거대한 배열이 아니라, 여러 개의 block으로 쪼개져 관리됩니다. 각 블록은 보통 64개의 포인터를 저장할 수 있는 고정 배열입니다.

 

말씀하신 대로 popleft()는 초기에는 논리적 삭제(포인터 이동)로 동작하다가, 특정 조건에서 물리적 해제가 발생합니다. 단, 그 방식이 전체 재할당이 아닌 블록 단위 해제입니다.

 

deque는 '전체 로드 팩터'를 계산하여 전체를 수축(Contraction)하지 않습니다. 대신 해당 블록이 완전히 비었을 때 그 블록만 떼어내어 메모리를 해제합니다.

 

정리하면 논리적 삭제를 하다가 블럭이 완전히 비는 조건이 되면 해당 블록만 떼어내어 메모리를 해제합니다.

 

 

기출 11회 작업형 2_전체 데이터 학습 여부

0

1

0

RateLimitError

0

4

1

예측값 결과 소수점 차이

0

13

2

여태까지 발견한 이슈들 공유드립니다.

1

11

1

기출 문제와 실전챌린지 연습문제 무엇부터 푸는게 나은가요?

0

10

0

전처리 train() test([ ])

0

11

2

작업형 1 배경지식 질문

0

13

2

옳게 풀은건지 질문드립니다!

0

11

1

roc_auc_score

0

22

2

재귀함수 연산법

0

11

2

추가질문 합니다

0

13

2

시험환경 구름

0

14

2

2유형 질문드려요

0

12

2

RandomForest vs lgb

0

22

2

전처리 관련질문

0

21

3

수강기간즘연장해주세요

0

10

1

작업형3 기출

0

15

2

유형2에서 데이터분할 생략 가능여부

0

26

2

9회 기출 유형3 질문

0

16

2

lgb 기초편

0

12

1

수업자료 문의

0

16

2

괄호 사용

0

20

2

작업형 2 데이터 전처리 질문

0

20

1

11회 기출 유형 작업형1 문제 3-1

0

17

1