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:
Using a Mutex Object in Java
Java Program to Implement Stack API
Converting Between a List and a Set in Java
Introduction to Netflix Archaius with Spring Cloud
Spring Boot - Database Handling
So sánh HashMap và Hashtable trong Java
Multipart Upload with HttpClient 4
File Upload with Spring MVC
Adding Parameters to HttpClient Requests
Check If a String Is Numeric in Java
Spring Boot Integration Testing with Embedded MongoDB
Một số tính năng mới về xử lý ngoại lệ trong Java 7
Java Program to Check Whether a Given Point is in a Given Polygon
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
Hướng dẫn Java Design Pattern – Builder
Java Program to Represent Graph Using 2D Arrays
Java Program to Implement ArrayDeque API
Java Program to Implement Hash Tables with Quadratic Probing
Guide to WeakHashMap in Java
Java Program to Find Transpose of a Graph Matrix
A Guide to the ResourceBundle
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Java Program to Compare Binary and Sequential Search
Lấy ngày giờ hiện tại trong Java
Java String Conversions
Weak References in Java
Java Program to Implement Affine Cipher
Sending Emails with Java
Spring Boot - Web Socket
Lớp HashMap trong Java
Java Map With Case-Insensitive Keys
Guide to DelayQueue