[질문]: [섹션4] -> [2중 연결 리스트로 전환] -> [21:30]
강의 잘 보고있습니다! 선생님.

다름이 아니라 ReleaseList()함수에서 어차피 이제 pTmp는 NULL인 상황을 고려할 필요가 없을텐데(테일 노드 역시 동적 할당이 아니므로), 조건식에 NULL을 고려하는 코드가 있어서 의문입니다. 제가 또 다른 경우의 수를 자각하고 있지 못하는 걸까요? 아니면 그냥 혹시나 NULL일 상황을 대비해서 남겨두신 코드인가요?

이런식으로 조건식을 바꾸더라도 프로그램은 정상 구동됩니다.
답변 2
0
안녕하세요, 인프런 AI 인턴입니다. 우아한 물소님, 질문해 주셔서 감사합니다.
ReleaseList() 함수의 내용을 살펴보면, 노드를 순차적으로 탐색하면서 해제하는 과정을 위해 특정 종료 조건을 가지고 있습니다. 여기서 종료 조건으로 pTmp != NULL을 포함하는 이유는 보호적인 프로그래밍 관점에서 고려된 것입니다.
이전 노드가 NULL이 아닐 경우에 대한 기능성을 보장하기 위해, 이러한 NULL 체크는 실수를 방지하기 위해 자주 사용됩니다. 특히, 다른 데이터 구조에서 어떤 예외 상황에서라도 오류를 줄이기 위해 NULL 여부를 체크하는 것은 좋은 프로그래밍 습관이라고 할 수 있습니다.
하지만 입문자 입장에서는 이러한 추가적인 안전장치는 불필요하게 보일 수 있으며, 코드 최적화라는 관점에서 변경할 수 있습니다. 추천해 주신 조건식 변경(pTmp != &g_DummyTailNode)은 충분히 가능합니다. 이런 방식으로도 프로그램이 정상적으로 동작할 수는 있습니다. 이는 g_DummyTailNode 만을 체크하여도 로직을 이탈하지 않기 때문입니다.
참고로 아래 링크로 문제와 유사한 질문에 대해 논의된 내용을 확인하실 수 있습니다:
- 이중 연결 리스트 AddNewNode 함수 질문: 이중 연결 리스트 구현에 관한 질문으로, 헤드와 테일 노드에 대한 구현 방법을 설명합니다.
더 궁금하신 점이나 추가 질문이 있으시면 계속해서 질문해 주세요. 지식공유자께서 친절하게 도움 주실 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
05_adtFileIO 개정이력에 대한 질문
0
41
2
마지막 열의 노드를 삭제하였을때 읽기 엑세스 위반 발생 건
0
60
2
첫번째 루프에서 최소값을 못찾았는데 계속 진행하는 이유가 무엇인가요?
0
46
1
인덱스정렬 강의, 04_ListAndIndex질문드립니다.
0
125
1
예제는 어디서 다운로드 받을 수 있나요?
0
178
2
04_MultiIndex 예제에서 질문이 있습니다
0
120
1
헤드노드에 관해..
0
230
3
AddNewNode 함수 구현시 질문입니다.
0
160
2
Event Loop
0
191
1
인덱스정렬 강의, 04_ListAndIndex질문드립니다.
0
191
1
CPU의 다른 이름 Machine 강의 질의
0
272
4
스택의 POP코드 질문드립니다.
0
259
1
adtFileIO 예제코드관련 질문 있습니다.
0
169
1
ADT강의 관련 질문 있습니다.
0
231
2
RangeSearch002 의 singlelist.c 파일 중 질문 있습니다.
0
191
1
섹션4 자료 자체와 정렬된 인덱스 분리 내용 질문
0
252
2
자료 자체와 정렬된 인덱스 분리 강의에서 질문
0
234
2
구현 연습에 대한 개인적 의문
0
279
1
05_adtFileIO 프로젝트 문의
0
317
2
CLI UI적용 강의에서 질문드립니다.
0
332
1
SearchToRemove와 RemoveNode가 분리되어야 할 필요가 있을까요?
0
293
1
05_adtFileIO 프로젝트 문의
0
256
1
자료 자체와 정렬된 인덱스 분리 (인덱스 정렬) - 인덱스 범위 코드에 버그가 있어서 질문 드립니다.
0
304
2
강의자료 관련
0
203
1





