인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

우아한 물소님의 프로필 이미지

작성한 질문수

독하게 C를 배운 사람을 위한 선형 자료구조

2중 연결 리스트로 전환

[질문]: [섹션4] -> [2중 연결 리스트로 전환] -> [21:30]

해결된 질문

작성

·

55

0

강의 잘 보고있습니다! 선생님.

 

image.png

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

image.png

이런식으로 조건식을 바꾸더라도 프로그램은 정상 구동됩니다.

답변 2

1

널널한 개발자님의 프로필 이미지
널널한 개발자
지식공유자

좋은 세상입니다. 인프런 AI 답변을 참고하시면 되겠습니다. 😄

0

인프런 AI 인턴님의 프로필 이미지

안녕하세요, 인프런 AI 인턴입니다. 우아한 물소님, 질문해 주셔서 감사합니다.

ReleaseList() 함수의 내용을 살펴보면, 노드를 순차적으로 탐색하면서 해제하는 과정을 위해 특정 종료 조건을 가지고 있습니다. 여기서 종료 조건으로 pTmp != NULL을 포함하는 이유는 보호적인 프로그래밍 관점에서 고려된 것입니다.

이전 노드가 NULL이 아닐 경우에 대한 기능성을 보장하기 위해, 이러한 NULL 체크는 실수를 방지하기 위해 자주 사용됩니다. 특히, 다른 데이터 구조에서 어떤 예외 상황에서라도 오류를 줄이기 위해 NULL 여부를 체크하는 것은 좋은 프로그래밍 습관이라고 할 수 있습니다.

하지만 입문자 입장에서는 이러한 추가적인 안전장치는 불필요하게 보일 수 있으며, 코드 최적화라는 관점에서 변경할 수 있습니다. 추천해 주신 조건식 변경(pTmp != &g_DummyTailNode)은 충분히 가능합니다. 이런 방식으로도 프로그램이 정상적으로 동작할 수는 있습니다. 이는 g_DummyTailNode 만을 체크하여도 로직을 이탈하지 않기 때문입니다.

참고로 아래 링크로 문제와 유사한 질문에 대해 논의된 내용을 확인하실 수 있습니다:

더 궁금하신 점이나 추가 질문이 있으시면 계속해서 질문해 주세요. 지식공유자께서 친절하게 도움 주실 것입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.