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:
Period and Duration in Java
Spring Cloud AWS – RDS
Java Program to Find Maximum Element in an Array using Binary Search
Java Program to Check the Connectivity of Graph Using DFS
Spring Security OAuth Login with WebFlux
Hướng dẫn sử dụng luồng vào ra nhị phân trong Java
Java Program to Implement Cartesian Tree
Injecting Prototype Beans into a Singleton Instance in Spring
Java Program to Implement the RSA Algorithm
How to Change the Default Port in Spring Boot
Guide to the Java TransferQueue
Lập trình hướng đối tượng (OOPs) trong java
Java Program to Check Cycle in a Graph using Graph traversal
Spring Boot Application as a Service
Enum trong java
Java Program to Search for an Element in a Binary Search Tree
Hướng dẫn kết nối cơ sở dữ liệu với Java JDBC
Lớp lồng nhau trong java (Java inner class)
New Features in Java 13
Java Program to Find Nearest Neighbor Using Linear Search
Object cloning trong java
A Guide to JUnit 5
Request a Delivery / Read Receipt in Javamail
Lập trình đa luồng với CompletableFuture trong Java 8
Spring Security 5 – OAuth2 Login
Spring Security Registration – Resend Verification Email
Java Program to Implement Graph Structured Stack
Read an Outlook MSG file
Java Program to Implement TreeMap API
Java Program to Implement Fenwick Tree
Java Program to Implement Heap
Java Program to Solve any Linear Equations