public class BinarSearchTree
{
private Node _tree;
public BinarSearchTree(List<int> datas)
{
if (datas != null)
{
foreach (var item in datas)
{
Insert(item);
}
}
}
public void Insert(int data)
{
if (_tree == null)
{
_tree = new Node(data);
}
else
{
var current = _tree;
while (current != null)
{
if (data > current.Data)
{
if (current.Right == null)
{
current.Right = new Node(data, current);
break;
}
current = current.Right;
}
else if (data < current.Data)
{
if (current.Left == null)
{
current.Left = new Node(data, current);
break;
}
current = current.Left;
}
}
}
}
public void Delete(int data)
{
var node = Find(data);
if (node == null) return;
if (node.Left == null && node.Right == null)
{
if (node.Parent == null)
{
_tree = null;
}
else
{
DeleteFromParent(node);
}
}
else if (node.Left != null && node.Right != null)
{
if (node.Parent == null)
{
_tree = null;
}
else
{
var minNode = node.Right;
var currentNode = node.Right;
while (currentNode != null)
{
minNode = currentNode;
currentNode = minNode.Left;
}
DeleteFromParent(minNode);
ReplaceChildNode(node, minNode);
}
}
else
{
var child = node.Left ?? node.Right;
if (node.Parent == null)
{
_tree = child;
}
else
{
ReplaceChildNode(node, child);
}
}
}
private void ReplaceChildNode(Node node, Node newNode)
{
newNode.Parent = node.Parent;
if (node.Parent.Left == node)
{
node.Parent.Left = newNode;
}
if (node.Parent.Right == node)
{
node.Parent.Right = newNode;
}
}
private void DeleteFromParent(Node node)
{
if (node.Parent.Left == node)
{
node.Parent.Left = null;
}
if (node.Parent.Right == node)
{
node.Parent.Right = null;
}
}
public Node Find(int data)
{
var current = _tree;
while (current != null)
{
if (data > current.Data)
{
current = current.Right;
}
else if (data < current.Data)
{
current = current.Left;
}
else
{
return current;
}
}
return null;
}
}
public class Node
{
public Node(int data, Node parent = null)
{
this.Data = data;
Parent = parent;
}
public int Data { get; set; }
public Node Left { get; set; }
public Node Right { get; set; }
public Node Parent { get; set; }
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律