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:
Connect through a Proxy
Java 8 – Powerful Comparison with Lambdas
Java Program to Implement HashSet API
A Guide to JUnit 5
Validate email address exists or not by Java Code
Spring Boot - Twilio
Guide to System.gc()
Guide to DelayQueue
Basic Authentication with the RestTemplate
Spring Boot - Tracing Micro Service Logs
Queue và PriorityQueue trong Java
Spring Security Logout
Java Program to Generate All Possible Combinations of a Given List of Numbers
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Thực thi nhiều tác vụ cùng lúc như thế nào trong Java?
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Spring Boot - Cloud Configuration Server
Composition, Aggregation, and Association in Java
Spring Security and OpenID Connect
Java Program to Implement Coppersmith Freivald’s Algorithm
Java equals() and hashCode() Contracts
Luồng Daemon (Daemon Thread) trong Java
Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not
Count Occurrences of a Char in a String
Build a REST API with Spring and Java Config
Checking for Empty or Blank Strings in Java
Java Program to Solve Travelling Salesman Problem for Unweighted Graph
Runnable vs. Callable in Java
Java Program to Show the Duality Transformation of Line and Point
Spring REST API + OAuth2 + Angular
Java Program to Construct an Expression Tree for an Postfix Expression
Guide to the Java ArrayList