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

This is a java program to construct a binary tree and perform in-order 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 Non-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 non recursive in order traversal of Binary Search Tree
import java.util.Scanner;
import java.util.Stack;
 
class BinarySearchTreeNode
{
    BinarySearchTreeNode left, right;
    int                  data;
 
    public BinarySearchTreeNode()
    {
        left = null;
        right = null;
        data = 0;
    }
 
    public BinarySearchTreeNode(int n)
    {
        left = null;
        right = null;
        data = n;
    }
 
    public void setLeft(BinarySearchTreeNode n)
    {
        left = n;
    }
 
    public void setRight(BinarySearchTreeNode n)
    {
        right = n;
    }
 
    public BinarySearchTreeNode getLeft()
    {
        return left;
    }
 
    public BinarySearchTreeNode getRight()
    {
        return right;
    }
 
    public void setData(int d)
    {
        data = d;
    }
 
    public int getData()
    {
        return data;
    }
}
 
class BinarySearchTreeOperations
{
    private BinarySearchTreeNodes root;
 
    public BinarySearchTreeOperations()
    {
        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)
            return;
 
        Stack<BinarySearchTreeNodes> stack = new Stack<BinarySearchTreeNodes>();
 
        while (!stack.isEmpty() || r != null)
        {
            if (r != null)
            {
                stack.push(r);
                r = r.left;
            } else
            {
                r = stack.pop();
                System.out.print(r.data + " ");
                r = r.right;
            }
        }
    }
}
 
public class Inorder_NonRecursive_BST
{
    public static void main(String[] args)
    {
        Scanner scan = new Scanner(System.in);
        BinarySearchTreeOperations bst = new BinarySearchTreeOperations();
        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_NonRecursive_BST.java
$ java Inorder_NonRecursive_BST
 
Enter the first 10 elements of the tree
 
12 4 10 13 15 46 78 98 45 12
 
In order   : 4 10 12 12 13 15 45 46 78 98

Related posts:

Generic Constructors in Java
Java Program to Implement Dijkstra’s Algorithm using Priority Queue
Java Program to Find Strongly Connected Components in Graphs
Generating Random Dates in Java
Introduction to Spring Data JPA
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
Giới thiệu Json Web Token (JWT)
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Spring Cloud – Adding Angular
Java Program to Implement Traveling Salesman Problem using Nearest neighbour Algorithm
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Converting Between Byte Arrays and Hexadecimal Strings in Java
Java Program to Implement Dijkstra’s Algorithm using Set
Spring Boot - Building RESTful Web Services
Java Program to Implement WeakHashMap API
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java Program to Implement Fibonacci Heap
Java Program to Perform Left Rotation on a Binary Search Tree
Java Program to Compare Binary and Sequential Search
Lập trình đa luồng trong Java (Java Multi-threading)
Connect through a Proxy
Java Program to Perform Deletion in a BST
Java Program to Represent Graph Using Adjacency List
Java Program to Find the GCD and LCM of two Numbers
Handling URL Encoded Form Data in Spring REST
LinkedHashSet trong java
Validations for Enum Types
The Spring @Controller and @RestController Annotations
Guide to java.util.concurrent.Locks
Copy a List to Another List in Java
Introduction to Java 8 Streams
Java Program to Implement Bellman-Ford Algorithm