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:

Spring MVC and the @ModelAttribute Annotation
Netflix Archaius with Various Database Configurations
Java Program to implement Bit Set
Recommended Package Structure of a Spring Boot Project
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Spring Boot Annotations
Biểu thức Lambda trong Java 8 – Lambda Expressions
HttpClient with SSL
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Java Program to Implement Hash Tables Chaining with List Heads
Hướng dẫn Java Design Pattern – Flyweight
Chuyển đổi từ HashMap sang ArrayList
Java Program to Find the Shortest Path from Source Vertex to All Other Vertices in Linear Time
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Mảng (Array) trong Java
Java Web Services – Jersey JAX-RS – REST và sử dụng REST API testing tools với Postman
Java Program to Show the Duality Transformation of Line and Point
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
Guide to Java 8 groupingBy Collector
Kết hợp Java Reflection và Java Annotations
Java Program to Implement Maximum Length Chain of Pairs
Transaction Propagation and Isolation in Spring @Transactional
Add Multiple Items to an Java ArrayList
Java Program to Generate a Sequence of N Characters for a Given Specific Case
So sánh Array và ArrayList trong Java
What is a POJO Class?
A Guide to the Java LinkedList
Sắp xếp trong Java 8
Giới thiệu luồng vào ra (I/O) trong Java
Java Program to Check the Connectivity of Graph Using DFS
Java Program to Find Nearest Neighbor Using Linear Search
A Guide to LinkedHashMap in Java