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 Implement PriorityBlockingQueue API
Spring REST API + OAuth2 + Angular
A Guide to the Java ExecutorService
Java Program to Implement Hamiltonian Cycle Algorithm
Working With Maps Using Streams
Java Program to Perform Searching Using Self-Organizing Lists
Tổng quan về ngôn ngữ lập trình java
An Intro to Spring Cloud Task
Java Program to Find Location of a Point Placed in Three Dimensions Using K-D Trees
Java Program to Implement ArrayDeque API
Java Program to Represent Graph Using 2D Arrays
Jackson Annotation Examples
Hướng dẫn sử dụng Java Reflection
Java Program to Test Using DFS Whether a Directed Graph is Weakly Connected or Not
Java Program to find the maximum subarray sum O(n^2) time(naive method)
Number Formatting in Java
Giới thiệu HATEOAS
Getting Started with GraphQL and Spring Boot
Spring @RequestMapping New Shortcut Annotations
Test a REST API with Java
Inject Parameters into JUnit Jupiter Unit Tests
Mix plain text and HTML content in a mail
Spring Boot - Actuator
Iterating over Enum Values in Java
Java Program to Check whether Graph is a Bipartite using BFS
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Implement Leftist Heap
Java Program to Implement Treap
Java Program to Perform Matrix Multiplication
Chuyển đổi Array sang ArrayList và ngược lại
ArrayList trong java
Quick Guide to Spring Controllers