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:
Intersection of Two Lists in Java
Hướng dẫn Java Design Pattern – Dependency Injection
Jackson – JsonMappingException (No serializer found for class)
Java – Reader to Byte Array
Configure a RestTemplate with RestTemplateBuilder
Hướng dẫn kết nối cơ sở dữ liệu với Java JDBC
How to Change the Default Port in Spring Boot
Java Program to Perform Uniform Binary Search
Java Program to Implement Bit Array
A Guide to JUnit 5 Extensions
A Guide to Spring Cloud Netflix – Hystrix
Spring Boot - Google Cloud Platform
Autoboxing và Unboxing trong Java
Java Program to Perform Partial Key Search in a K-D Tree
Java – String to Reader
Exploring the Spring Boot TestRestTemplate
Java Program to Implement Find all Forward Edges in a Graph
Spring Cloud AWS – EC2
Quản lý bộ nhớ trong Java với Heap Space vs Stack
How to Read a Large File Efficiently with Java
Java Program to Implement Network Flow Problem
Biến trong java
Java Program to Implement Regular Falsi Algorithm
Java Program to Find Minimum Number of Edges to Cut to make the Graph Disconnected
Guide to BufferedReader
Java Program to Permute All Letters of an Input String
Java Program to Check Whether an Undirected Graph Contains a Eulerian Cycle
Spring Security OAuth2 – Simple Token Revocation
Hướng dẫn Java Design Pattern – Abstract Factory
Java Program to Implement Hash Trie
Java Program to Implement Sparse Array
Java Program to Generate a Graph for a Given Fixed Degree Sequence