BST:노드 제거
1456 단어 두 갈래 나무
방법1: 이 노드를 찾아서 이 노드의 오른쪽 노드를 대체하고 이 노드의 왼쪽 트리를 오른쪽 노드의 맨 왼쪽 아래 노드의 left에 연결합니다.
public TreeNode deleteNode(TreeNode root, int key) {
if(root == null)
return null;
TreeNode node = root;
TreeNode pre = null;
boolean isLeft = true;
while(node != null && node.val != key){ // key
pre = node;
if(key < node.val){
node = node.left;
isLeft = true;
}
else{
node = node.right;
isLeft = false;
}
}
if(node == null) // ,
return root;
if(node.right == null){ // null,
if(pre == null) return node.left;
else{
if(isLeft) pre.left = node.left;
else pre.right = node.left;
return root;
}
}
else{ //node.right != null
TreeNode l = node.left;
TreeNode r = node.right;
node = node.right;
while(node.left != null){ //
node = node.left;
}
node.left = l;
if(pre == null)
return r;
else{
if(isLeft) pre.left = r;
else pre.right = r;
return root;
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
java 데이터 구조 2차원 트리의 실현 코드일.두 갈래 트리 인터페이스 2 노드 클래스 3. 두 갈래 나무 구현 이 글을 통해 여러분께 도움이 되었으면 좋겠습니다. 본 사이트에 대한 지지에 감사드립니다!...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.