J'ai écrit un code pour insérer un élément dans un arbre binaire en Java. Voici les fonctions pour faire la même chose:Insertion d'éléments dans un arbre binaire en Java
public void insert(int data)
{
root = insert(root, data);
}
private Node insert(Node node, int data)
{
if (node == null)
node = new Node(data);
else
{
if (node.getRight() == null)
node.right = insert(node.right, data);
else
node.left = insert(node.left, data);
}
return node;
}
Cependant quand je traverse l'arbre, la réponse que je reçois est fausse. Voici les fonctions traversal (pré-commande):
public void preorder()
{
preorder(root);
}
private void preorder(Node r)
{
if (r != null)
{
System.out.print(r.getData() +" ");
preorder(r.getLeft());
preorder(r.getRight());
}
}
Bon alors comme suggéré ici est la définition de la classe Node:
public class Node {
public int data;
public Node left, right;
/* Constructor */
public Node() {
left = null;
right = null;
data = 0;
}
/* Constructor */
public Node(int d, Node l, Node r) {
data = d;
left = l;
right = r;
}
//Constructor
public Node(int d) {
data = d;
}
/* Function to set link to next Node */
public void setLeft(Node l) {
left = l;
}
/* Function to set link to previous Node */
public void setRight(Node r) {
right = r;
}
/* Function to set data to current Node */
public void setData(int d) {
data = d;
}
/* Function to get link to next node */
public Node getLeft() {
return left;
}
/* Function to get link to previous node */
public Node getRight() {
return right;
}
/* Function to get data from current Node */
public int getData() {
return data;
}
}
Je revérifié l'algorithme de traversal plusieurs fois, et il travaille à la perfection. Je crois que le problème est dans l'algorithme d'insertion. Aucune suggestion?
S'il vous plaît examiner les réponses réfléchies ci-dessous, merci. –