Java Program to Perform Inorder Recursive Traversal of a Given Binary Tree

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:

Java Program to Implement the Monoalphabetic Cypher
Spring REST API + OAuth2 + Angular
Java Program to Compute the Area of a Triangle Using Determinants
Spring Boot - Tracing Micro Service Logs
New Features in Java 15
Java Program to Find Minimum Number of Edges to Cut to make the Graph Disconnected
Comparing Two HashMaps in Java
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
Java Program to Find the Mode in a Data Set
How to Iterate Over a Stream With Indices
Java Program to Implement Hash Tables Chaining with List Heads
Java Program to Perform Optimal Paranthesization Using Dynamic Programming
Spring Security Registration – Resend Verification Email
Mệnh đề if-else trong java
Spring Cloud – Tracing Services with Zipkin
Send an email with an attachment
Automatic Property Expansion with Spring Boot
JPA/Hibernate Persistence Context
Hướng dẫn Java Design Pattern – Template Method
Connect through a Proxy
The Registration Process With Spring Security
Java Program to Implement Binary Heap
Spring Security 5 – OAuth2 Login
Java Program to Implement Euler Circuit Problem
DistinctBy in the Java Stream API
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Guide to the Volatile Keyword in Java
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Java Program to Implement Sieve Of Eratosthenes
Java Program to add two large numbers using Linked List
Posting with HttpClient
Java Program to Implement Find all Forward Edges in a Graph