[英]Recursive binary tree insert
當我將節點添加到二叉樹中並嘗試顯示有關它的信息時,信息未顯示。 我認為我在遞歸插入算法中有一些參考問題,但無法修復它。
package test;
class BinaryTree<T> {
private static class Node<T> {
int key;
T data;
Node<T> leftChild;
Node<T> rightChild;
public Node(int key,T data) {
this.key = key;
this.data = data;
}
}
public Node<T> rootNode;
public BinaryTree() {
rootNode = null;
}
public Node<T> getRootNode() {
return rootNode;
}
// insert node into binary tree
public void insertNode(int key,T data, Node<T> rootNode) {
// to create new node
// if tree doesn't have root elements
if(rootNode == null) {
rootNode = new Node<T>(key,data);
rootNode.leftChild = null;
rootNode.rightChild = null;
}
else {
Node<T> focusNode = rootNode;
if(key >= focusNode.key) {
insertNode(key,data,focusNode.rightChild);
}
else {
insertNode(key,data,focusNode.leftChild);
}
}
}
// inorder traverse tree
public void inOrderTraverseTree(Node<T> focusNode) {
if(focusNode != null) {
inOrderTraverseTree(focusNode.leftChild);
System.out.println(focusNode.data);
inOrderTraverseTree(focusNode.rightChild);
}
}
}
public class MyApp {
public static void main(String[] args) {
BinaryTree<String> bintree = new BinaryTree<String>();
bintree.insertNode(3, "Boss", bintree.rootNode);
bintree.inOrderTraverseTree(bintree.rootNode);
}
}
如果我使用此算法添加節點並嘗試顯示信息,則可以正常工作。 如何解決遞歸算法的問題?
public void addNode(int key, T name) {
Node<T> newNode = new Node<T>(key,name);
if(rootNode == null) {
rootNode = newNode;
}
else {
Node<T> focusNode = rootNode;
Node<T> parent;
while(true) {
parent = focusNode;
if(key < focusNode.key) {
focusNode = focusNode.leftChild;
if(focusNode == null) {
parent.leftChild = newNode;
return;
}
}
else {
focusNode = focusNode.rightChild;
if(focusNode == null) {
parent.rightChild = newNode;
return;
}
}
}
}
}
謝謝你的幫助。
快速瀏覽一下代碼 - 我發現你正在檢查null的那一部分,rootNode變量是函數的本地變量。 因此,您創建的新節點在函數退出后立即被丟棄,它不會更改您的成員字段
// if tree doesn't have root elements
if(rootNode == null) {
rootNode = new Node<T>(key,data);
rootNode.leftChild = null;
rootNode.rightChild = null;
}
你需要使用this.rootNode = new Node<T>(key,data);
相反,或使用不同的局部變量名稱以避免混淆
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.