当我在main方法中调用print方法时,它在控制台上什么都不打印。 我试图按字母顺序制作二叉搜索树。为什么会这样?我的插入方法和添加方法是否正确?或者,打印方法有问题吗?
public class Node
{
String value;
Node leftChild;
Node rightChild;
Node(String val,Node left, Node right)
{
value = val;
leftChild = left;
rightChild = right;
}
Node(String val)
{
value = val;
leftChild = null;
rightChild = null;
}
}
public class binarySearchTree
{
Node root;
binarySearchTree()
{
root = null;
}
public Node search(String element)
{
Node current = root;
while (element.compareTo(current.value) != 0 )
{
if(current == null)
return null;
else
{
if(element.compareTo(current.value) < 0)
{
current = current.leftChild;
}
else
current = current.rightChild;
}
}
return current;
}
public Node add(String element, Node bstree)
{
if(bstree == null)
{
return new Node(element);
}
else if(element.compareTo(bstree.value) < 0)
{
bstree.leftChild = add(element, bstree.leftChild);
}
else
{
bstree.rightChild = add(element, bstree.rightChild);
}
return bstree;
}
public void insert(String element)
{
add(element,root);
}
public void print(Node bstree)
{
if(bstree != null)
{
print(bstree.leftChild);
System.out.print(bstree.value + " ");
print(bstree.rightChild);
}
}
}
public class testing
{
public static void main(String[] agrs)
{
binarySearchTree tree = new binarySearchTree();
tree.insert("apple");
tree.insert("banana");
tree.insert("kiwi");
tree.print(tree.root);
}
}
答案 0 :(得分:0)
您没有考虑可能添加到空树的可能性,在这种情况下,您需要专门设置根节点:
public Node add(String element, Node bstree)
{
if (root == null)
{
root = new Node(element);
return root;
}
if (bstree == null)
{
return new Node(element);
}
else if (element.compareTo(bstree.value) < 0)
{
bstree.leftChild = add(element, bstree.leftChild);
}
else
{
bstree.rightChild = add(element, bstree.rightChild);
}
return bstree;
}
答案 1 :(得分:0)
我不确定这是你需要的解决方案,但我知道为什么你不能打印所有元素。查看你的构造函数,你创建了一个带有根元素的BinaryTree,总是为null。在第一次插入新元素时,函数节点add(String element,Node bstree)被调用并返回 new Node()。为什么你不将新节点分配给当前的Btree,因为Btree仍然是空的?我们有几个解决方案来解决它。这是我的观点:
创建新的构造函数:
public BinarySearchTree(Node root){ this.root = root; }
我改变主要功能如下:
BinarySearchTree tree = new BinarySearchTree(new Node(&#34; apple&#34;));
P / s:我创建了一个BTree(与你的BTree不同)。你可以在这里看到:BST-Level-Order-Traversal