当前位置: 首页 > news >正文

Java | Leetcode Java题解之第450题删除二叉搜索树中的节点

题目:

题解:

class Solution {public TreeNode deleteNode(TreeNode root, int key) {TreeNode cur = root, curParent = null;while (cur != null && cur.val != key) {curParent = cur;if (cur.val > key) {cur = cur.left;} else {cur = cur.right;}}if (cur == null) {return root;}if (cur.left == null && cur.right == null) {cur = null;} else if (cur.right == null) {cur = cur.left;} else if (cur.left == null) {cur = cur.right;} else {TreeNode successor = cur.right, successorParent = cur;while (successor.left != null) {successorParent = successor;successor = successor.left;}if (successorParent.val == cur.val) {successorParent.right = successor.right;} else {successorParent.left = successor.right;}successor.right = cur.right;successor.left = cur.left;cur = successor;}if (curParent == null) {return cur;} else {if (curParent.left != null && curParent.left.val == key) {curParent.left = cur;} else {curParent.right = cur;}return root;}}
}

http://www.mrgr.cn/news/40930.html

相关文章:

  • 智能平衡移动机器人-平台硬件电路
  • 【Linux 24】网络基础概念
  • SolidWorks机器转ROS2 URDF
  • Oracle exadata存储节点更换内存操作及报错处理
  • MySQL--数据库约束(详解)
  • C语言 | Leetcode C语言题解之题451题根据字符出现频率排序
  • 可视化图表与源代码显示配置项及页面的动态调整功能分析
  • C++ | Leetcode C++题解之第451题根据字符出现频率排序
  • Linux 实用工具Axel安装及使用教程(支持多线程下载)
  • SD-WebUI forge支持flux模型。算力互联forge镜像使用教程
  • Unity Input System自动生成配置
  • AccessoriesqueryController
  • Difference of Convex Relaxation (DC)
  • 基于深度学习的任务序列中的快速适应
  • Hive数仓操作(十)
  • 课设实验-数据结构-线性表-手机销售
  • 2024多模态大模型发展调研
  • buuctf--->Youngter-drive
  • 复习HTML(基础)
  • 重置linux后vscode无法再次使用ssh连接