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:
Java Program to Compute Determinant of a Matrix
Java Program to Implement AVL Tree
Spring Boot - Interceptor
String Operations with Java Streams
Java Program to Implement Hash Tables Chaining with Binary Trees
Multi Dimensional ArrayList in Java
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
Spring 5 and Servlet 4 – The PushBuilder
Từ khóa this và super trong Java
Hướng dẫn Java Design Pattern – Facade
Java Program to Implement Quick sort
Build a REST API with Spring and Java Config
Java Program to Implement Counting Sort
Properties with Spring and Spring Boot
Java Program to Perform Partition of an Integer in All Possible Ways
Java Program to Implement Sorted Circularly Singly Linked List
Stack Memory and Heap Space in Java
Java – File to Reader
Java Program to Implement Binomial Tree
Show Hibernate/JPA SQL Statements from Spring Boot
Java Program to Implement Iterative Deepening
Disable Spring Data Auto Configuration
Java 8 and Infinite Streams
Receive email using IMAP
Spring Boot - Cloud Configuration Client
Hướng dẫn Java Design Pattern – Dependency Injection
Spring Boot - Twilio
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Database Migrations with Flyway
Java Program to Implement Self organizing List
@Lookup Annotation in Spring
HashSet trong Java hoạt động như thế nào?