450. Delete Node in a BST
Given a root node reference of a BST and a key, delete the node with the given key in the BST. Return the root node reference (possibly updated) of the BST.
Basically, the deletion can be divided into two stages:
- Search for a node to remove.
- If the node is found, delete the node.
Note: Time complexity should be O(height of tree).
Example:
root = [5,3,6,2,4,null,7] key = 3 5 / \ 3 6 / \ \ 2 4 7 Given key to delete is 3. So we find the node with value 3 and delete it. One valid answer is [5,4,6,2,null,null,7], shown in the following BST. 5 / \ 4 6 / \ 2 7 Another valid answer is [5,2,6,null,4,null,7]. 5 / \ 2 6 \ \ 4 7
含义:现在有一个二叉搜索树,现在要让你删除一个节点,并且保证整个BST的性质不变
1 /** 2 * Definition for a binary tree node. 3 * public class TreeNode { 4 * int val; 5 * TreeNode left; 6 * TreeNode right; 7 * TreeNode(int x) { val = x; } 8 * } 9 */ 10 class Solution { 11 12 public TreeNode deleteNode(TreeNode root, int key) { 13 if(root == null){ 14 return null; 15 } 16 if(key < root.val){ 17 root.left = deleteNode(root.left, key); 18 }else if(key > root.val){ 19 root.right = deleteNode(root.right, key); 20 }else{ 21 if(root.left == null){ 22 return root.right; 23 }else if(root.right == null){ 24 return root.left; 25 } 26 //右子树中最小值挪到当前root上,才能保持二叉树性质不变 27 TreeNode minNode = findMin(root.right); 28 root.val = minNode.val; 29 root.right = deleteNode(root.right, root.val); 30 } 31 return root; 32 } 33 34 private TreeNode findMin(TreeNode node){ 35 while(node.left != null){ 36 node = node.left; 37 } 38 return node; 39 } 40 }
分类:
leetcode_tree
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!