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:
Hướng dẫn Java Design Pattern – State
Getting Started with Stream Processing with Spring Cloud Data Flow
Spring Boot - Rest Template
Introduction to Spring MVC HandlerInterceptor
A Custom Data Binder in Spring MVC
A Guide to System.exit()
Integer Constant Pool trong Java
Registration – Activate a New Account by Email
Auditing with JPA, Hibernate, and Spring Data JPA
Java Program to Implement HashTable API
Lớp LinkedHashMap trong Java
Add Multiple Items to an Java ArrayList
Java Program to Implement Hash Tables with Double Hashing
Spring 5 WebClient
Java Program to Check Whether a Directed Graph Contains a Eulerian Path
Spring Cloud – Tracing Services with Zipkin
Introduction to Spring Method Security
Java Program to Find the Minimum Element of a Rotated Sorted Array using Binary Search approach
Tính trừu tượng (Abstraction) trong Java
Using Custom Banners in Spring Boot
Spring Boot Tutorial – Bootstrap a Simple Application
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
A Comparison Between Spring and Spring Boot
A Guide to Java 9 Modularity
Versioning a REST API
Java Program to Implement Naor-Reingold Pseudo Random Function
Java Program to Implement Traveling Salesman Problem using Nearest neighbour Algorithm
Java Program to Implement Insertion Sort
Java Program to Implement Binary Tree
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
An Introduction to Java.util.Hashtable Class
Java Program to Implement Circular Doubly Linked List