This is a java program to construct a binary tree and perform inorder traversal of the constructed binary tree.
Nodes visited are in the order:
visit Left node
visit Root node
visit Right node
Here is the source code of the Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a java program to implement recursive inorder traversal of the Binary Search Tree
import java.util.Scanner;
class BinarySearchTreeNodes
{
BinarySearchTreeNodes left, right;
int data;
public BinarySearchTreeNodes()
{
left = null;
right = null;
data = 0;
}
public BinarySearchTreeNodes(int n)
{
left = null;
right = null;
data = n;
}
public void setLeft(BinarySearchTreeNodes n)
{
left = n;
}
public void setRight(BinarySearchTreeNodes n)
{
right = n;
}
public BinarySearchTreeNodes getLeft()
{
return left;
}
public BinarySearchTreeNodes getRight()
{
return right;
}
public void setData(int d)
{
data = d;
}
public int getData()
{
return data;
}
}
class BinarySearchTree
{
private BinarySearchTreeNodes root;
public BinarySearchTree()
{
root = null;
}
public boolean isEmpty()
{
return root == null;
}
public void insert(int data)
{
root = insert(root, data);
}
private BinarySearchTreeNodes insert(BinarySearchTreeNodes node, int data)
{
if (node == null)
node = new BinarySearchTreeNodes(data);
else
{
if (data <= node.getData())
node.left = insert(node.left, data);
else
node.right = insert(node.right, data);
}
return node;
}
public void inorder()
{
inorder(root);
}
private void inorder(BinarySearchTreeNodes r)
{
if (r != null)
{
inorder(r.getLeft());
System.out.print(r.getData() + " ");
inorder(r.getRight());
}
}
}
public class Inorder_Recursive_BST
{
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
BinarySearchTree bst = new BinarySearchTree();
System.out.println("Enter the first 10 elements of the tree\n");
int N = 10;
for (int i = 0; i < N; i++)
bst.insert(scan.nextInt());
System.out.print("\nIn order : ");
bst.inorder();
scan.close();
}
}
Output:
$ javac Inorder_Recursive_BST.java $ java Inorder_Recursive_BST Enter the first 10 elements of the tree 12 10 11 03 15 19 02 01 04 70 In order : 1 2 3 4 10 11 12 15 19 70
Related posts:
Using JWT with Spring Security OAuth
Java Program to Perform Naive String Matching
Java InputStream to String
A Comparison Between Spring and Spring Boot
Java Program to Generate All Subsets of a Given Set in the Lexico Graphic Order
Returning Custom Status Codes from Spring Controllers
Shuffling Collections In Java
Java Program to Implement the String Search Algorithm for Short Text Sizes
Java Program to Implement Fibonacci Heap
Quick Guide to Spring Bean Scopes
Java 8 StringJoiner
String Joiner trong Java 8
Java Program to Implement Skew Heap
Java Multi-line String
Create a Custom Auto-Configuration with Spring Boot
Java – Create a File
Registration – Activate a New Account by Email
Function trong Java 8
Java Switch Statement
Java Program to Implement CopyOnWriteArraySet API
Hướng dẫn Java Design Pattern – Object Pool
Number Formatting in Java
Java Program to Implement Graph Coloring Algorithm
Hướng dẫn Java Design Pattern – MVC
Java Program to Check if an UnDirected Graph is a Tree or Not Using DFS
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
A Guide to Java SynchronousQueue
Java Program to Implement Stein GCD Algorithm
Using a Custom Spring MVC’s Handler Interceptor to Manage Sessions
Spring Security with Maven
Create Java Applet to Simulate Any Sorting Technique
Receive email by java client