450. 删除二叉搜索树中的节点

这里就把二叉搜索树中删除节点遇到的情况都搞清楚。
有以下五种情况:

  • 第一种情况:没找到删除的节点,遍历到空节点直接返回了
  • 找到删除的节点
    • 第二种情况:左右孩子都为空(叶子节点),直接删除节点, 返回NULL为根节点
    • 第三种情况:删除节点的左孩子为空,右孩子不为空,删除节点,右孩子补位,返回右孩子为根节点
    • 第四种情况:删除节点的右孩子为空,左孩子不为空,删除节点,左孩子补位,返回左孩子为根节点
    • 第五种情况:左右孩子节点都不为空,则将删除节点的左子树头结点(左孩子)放到删除节点的右子树的最左面节点的左孩子上,返回删除节点右孩子为新的根节点。
      1. class Solution {
      2. public:
      3. TreeNode* pre = NULL;
      4. TreeNode* deleteNode(TreeNode* root, int key) {
      5. if(root == NULL)return root;
      6. if(root->val == key)
      7. {
      8. if(root->left==NULL && root->right==NULL)
      9. return NULL;
      10. else if(root->left==NULL)
      11. return root->right;
      12. else if(root->right==NULL)
      13. return root->left;
      14. else
      15. {
      16. //找到当前结点右子树最左面的叶子结点
      17. TreeNode* cur = root->right;
      18. while(cur->left!=NULL)
      19. cur = cur->left;
      20. cur->left = root->left;
      21. return root->right;
      22. }
      23. }
      24. if(root->val>key)root->left = deleteNode(root->left,key);
      25. if(root->val<key)root->right = deleteNode(root->right,key);
      26. return root;
      27. }
      28. };