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;}};
