我正在尝试在C#中实现二叉树,而不是二叉搜索树。我实现了下面的代码,它可以正常工作,但不是我想要的结果。基本上,我正在尝试实现一个完全二叉树,但使用我的下面的代码,我得到的是一个不平衡的二叉树。
Input : 10, 20, 30, 40, 50, 60, 70, 80, 90, 100
Desired Output :
10
/ \
20 30
/ \ / \
40 50 60 70
/ \ /
80 90 100
Current Output :
10
/ \
20 30
/ \
40 50
/ \
60 70
/ \
80 90
/
100
这是我的代码:
class Node
{
public int data;
public Node left;
public Node right;
public Node()
{
data = 0;
left = null;
right = null;
}
}
class Tree
{
private Node root;
public Tree()
{
root = null;
}
public void AddNode(int data)
{
root = AddNode(root, data);
}
public Node AddNode(Node node, int data)
{
if (node == null)
{
node = new Node();
node.data = data;
}
else
{
if (node.left == null)
{
node.left = AddNode(node.left, data);
}
else
{
node.right = AddNode(node.right, data);
}
}
return node;
}
}
class Program
{
static void Main(string[] args)
{
int[] nodeData = {10, 20, 30, 40, 50, 60, 70, 80, 90, 100};
Tree tree1 = new Tree();
foreach (int i in nodeData)
{
tree1.AddNode(i);
}
Console.ReadKey();
}
}
我知道问题出在我的AddNode(Node node, int data) {...}函数的else块中,但我无法找到解决方法。
我尝试在网上寻找解决方案,但大多数地方都是二叉搜索树的实现。我喜欢的一个解决方案在这里,但该解决方案将输入数组作为递归调用的参数传递,我不知道在处理非常大的树时是否高效。还有其他几篇帖子,但没有一个能解决我的问题。
虽然我正在使用C#实现它,但更具体地说,我正在寻找修复AddNode(...)函数的逻辑,所以如果算法不是代码实现,则可以接受。
有什么帮助吗?