이진 탐색 트리 - 제거 구현 질문 있습니다!
- 학습 관련 질문을 남겨주세요. 상세히 작성하면 더 좋아요!
- 먼저 유사한 질문이 있었는지 검색해보세요.
- 서로 예의를 지키며 존중하는 문화를 만들어가요.
- 잠깐! 인프런 서비스 운영 관련 문의는 1:1 문의하기를 이용해주세요.
노드를 삭제할 때 자식 노드가 양쪽 다 있는 경우의 코드중 일부분 입니다.
if (replacingNodeParent.getLeftSubTree() == replacingNode) {
replacingNodeParent.setLeftSubTree(replacingNode.getLeftSubTree());
} else {
replacingNodeParent.setRightSubTree(replacingNode.getLeftSubTree());
}
위 코드에서 replacingNode는 해당 트리중 가장 큰 값이니까 무조건 replacingNodeParent의 오른쪽 자식일 것 같아서 아래와 같이 작성해도 될 것 같은데 혹시 제가 생각하지 못한 다른 케이스가 있을까요?
replacingNodeParent.setRightSubTree(replacingNode.getLeftSubTree());
Answer 1
10

위 트리에서 10을 제거하는 상황에 if문이 참이됩니다!
7의 오른쪽 자식이 없는 상황으로 10노드를 7이 대체하고, 3을 왼쪽 자식으로 새롭게 연결하는 케이스입니다.
궁금증이 해결되셨나요? ㅎㅎ
문제 생각 몇분정도가 좋을까요
0
253
1
self
2
639
1
Two sum
2
334
1
Test_queue 출력 오류
1
547
2
int 범위
2
321
1
시간복잡도
1
1372
1
심화 과정 커리큘럼 질문
1
526
1
자바스크립트 사용하는데
1
579
2
11:50 동적 배열
1
337
1
강의교재 노션 계정 변경
1
335
1
강의 교재 Notion 공유 요청 했는데 응답이 없어요
1
383
1
Live 문제풀이 업데이트 날짜
1
308
1
프로그래머스나 백준 확인해보니까
1
1289
2
[코테 적용] LIFO 2번째 문제 시간복잡도 질문
2
519
2
BFS 질문 있습니다.
1
248
1
동적배열 7:35
1
340
1
else if 질문 있습니다.
1
372
2
시간복잡도 질문
2
483
1
이해가됐습니다...
2
554
1
하위문제 하향식 계산이 정확히 뭔지 모르겠습니다.
1
364
1
34강 얕은 복사 깊은 복사 관련 문의
1
506
1
동적배열 8:23
1
367
1
연결리스트(Linked List)-1 전반적인 코드
2
721
1
연결리스트 질문입니다.
2
466
1

