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 Find ith Largest Number from a Given List Using Order-Statistic Algorithm
Working with Network Interfaces in Java
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to Solve the 0-1 Knapsack Problem
Jackson Ignore Properties on Marshalling
A Guide to the ResourceBundle
Java Program to Perform the Shaker Sort
A Guide to BitSet in Java
Quick Guide to Spring Controllers
Java Program to Implement Ternary Search Algorithm
JWT – Token-based Authentication trong Jersey 2.x
Spring Boot Actuator
Java Program to Construct an Expression Tree for an Postfix Expression
Java – Combine Multiple Collections
Java Program to Implement RoleUnresolvedList API
A Guide to the Java LinkedList
Spring WebClient and OAuth2 Support
Java Program to Implement Rope
DynamoDB in a Spring Boot Application Using Spring Data
Add Multiple Items to an Java ArrayList
Hướng dẫn Java Design Pattern – Interpreter
Từ khóa this và super trong Java
Runnable vs. Callable in Java
Java Program to Implement Disjoint Sets
Adding Parameters to HttpClient Requests
Java Program for Douglas-Peucker Algorithm Implementation
Java Program to Implement Slicker Algorithm that avoids Triangulation to Find Area of a Polygon
Calling Stored Procedures from Spring Data JPA Repositories
Lớp Arrarys trong Java (Arrays Utility Class)
Period and Duration in Java
Map Interface trong java
Tránh lỗi NullPointerException trong Java như thế nào?