1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
class Solution { public: TreeNode* deleteNode(TreeNode* root, int key) { if(!root) return nullptr; if(key > root->val) root->right = deleteNode(root->right, key); else if(key < root->val) root->left = deleteNode(root->left, key); else { if(!root->left && !root->right) { delete root; return nullptr; } if(root->right) { root->val = rightMin(root->right); root->right = deleteNode(root->right, root->val); }else { root->val = leftMax(root->left); root->left = deleteNode(root->left, root->val); } } return root; } private: int rightMin(TreeNode* node) { while(node->left) node = node->left; return node->val; }
int leftMax(TreeNode* node) { while(node->right) node = node->right; return node->val; } };
|