450. 删除二叉搜索树中的节点
这里就把二叉搜索树中删除节点遇到的情况都搞清楚。
有以下五种情况:
- 第一种情况:没找到删除的节点,遍历到空节点直接返回了
- 找到删除的节点
- 第二种情况:左右孩子都为空(叶子节点),直接删除节点, 返回NULL为根节点
- 第三种情况:删除节点的左孩子为空,右孩子不为空,删除节点,右孩子补位,返回右孩子为根节点
- 第四种情况:删除节点的右孩子为空,左孩子不为空,删除节点,左孩子补位,返回左孩子为根节点
- 第五种情况:左右孩子节点都不为空,则将删除节点的左子树头结点(左孩子)放到删除节点的右子树的最左面节点的左孩子上,返回删除节点右孩子为新的根节点。
class Solution {
public:
TreeNode* pre = NULL;
TreeNode* deleteNode(TreeNode* root, int key) {
if(root == NULL)return root;
if(root->val == key)
{
if(root->left==NULL && root->right==NULL)
return NULL;
else if(root->left==NULL)
return root->right;
else if(root->right==NULL)
return root->left;
else
{
//找到当前结点右子树最左面的叶子结点
TreeNode* cur = root->right;
while(cur->left!=NULL)
cur = cur->left;
cur->left = root->left;
return root->right;
}
}
if(root->val>key)root->left = deleteNode(root->left,key);
if(root->val<key)root->right = deleteNode(root->right,key);
return root;
}
};