This is a java program to construct a binary tree and perform inorder 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 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 recursive inorder traversal of the Binary Search Tree
import java.util.Scanner;
class BinarySearchTreeNodes
{
BinarySearchTreeNodes left, right;
int data;
public BinarySearchTreeNodes()
{
left = null;
right = null;
data = 0;
}
public BinarySearchTreeNodes(int n)
{
left = null;
right = null;
data = n;
}
public void setLeft(BinarySearchTreeNodes n)
{
left = n;
}
public void setRight(BinarySearchTreeNodes n)
{
right = n;
}
public BinarySearchTreeNodes getLeft()
{
return left;
}
public BinarySearchTreeNodes getRight()
{
return right;
}
public void setData(int d)
{
data = d;
}
public int getData()
{
return data;
}
}
class BinarySearchTree
{
private BinarySearchTreeNodes root;
public BinarySearchTree()
{
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)
{
inorder(r.getLeft());
System.out.print(r.getData() + " ");
inorder(r.getRight());
}
}
}
public class Inorder_Recursive_BST
{
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
BinarySearchTree bst = new BinarySearchTree();
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_Recursive_BST.java $ java Inorder_Recursive_BST Enter the first 10 elements of the tree 12 10 11 03 15 19 02 01 04 70 In order : 1 2 3 4 10 11 12 15 19 70
Related posts:
Java Program to Implement Multi-Threaded Version of Binary Search Tree
Java Program to Implement Shoelace Algorithm
Introduction to Thread Pools in Java
Adding Shutdown Hooks for JVM Applications
Java Program to Implement Double Ended Queue
Custom Thread Pools In Java 8 Parallel Streams
Java Program to Perform the Sorting Using Counting Sort
Spring JDBC
Java Program to Perform integer Partition for a Specific Case
Java – Generate Random String
Check If a String Is Numeric in Java
Consuming RESTful Web Services
MyBatis with Spring
Java Program to Implement Word Wrap Problem
Custom Exception trong Java
Java Program to Implement Maximum Length Chain of Pairs
Java Program to Find Minimum Element in an Array using Linear Search
Basic Authentication with the RestTemplate
Build a REST API with Spring and Java Config
Call Methods at Runtime Using Java Reflection
Java Program to Implement Fibonacci Heap
Tạo ứng dụng Java RESTful Client không sử dụng 3rd party libraries
File Upload with Spring MVC
Concatenating Strings In Java
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Working with Kotlin and JPA
Running Spring Boot Applications With Minikube
Java Program to Represent Graph Using Linked List
Show Hibernate/JPA SQL Statements from Spring Boot
HttpClient 4 Cookbook
Java Program to Encode a Message Using Playfair Cipher
Java Program to Implement Repeated Squaring Algorithm