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:
Immutable Map Implementations in Java
Getting Started with Custom Deserialization in Jackson
Rest Web service: Filter và Interceptor với Jersey 2.x (P2)
A Guide to Java SynchronousQueue
Java InputStream to String
Spring Data – CrudRepository save() Method
Java Perform to a 2D FFT Inplace Given a Complex 2D Array
ETL with Spring Cloud Data Flow
Guide to java.util.concurrent.Locks
Java Program to Implement Multi-Threaded Version of Binary Search Tree
Java Program to implement Bit Set
Spring Data MongoDB Transactions
Introduction to Using FreeMarker in Spring MVC
Adding Parameters to HttpClient Requests
Java Program to Implement Selection Sort
Java Program to Implement the Monoalphabetic Cypher
Java Program to Solve any Linear Equations
A Guide to ConcurrentMap
Beans and Dependency Injection
Spring RestTemplate Request/Response Logging
Java Program to Implement ConcurrentSkipListMap API
Java Program to Compute Discrete Fourier Transform Using the Fast Fourier Transform Approach
Control the Session with Spring Security
Java Program to Implement the linear congruential generator for Pseudo Random Number Generation
Deque và ArrayDeque trong Java
Circular Dependencies in Spring
Java Program to Check whether Directed Graph is Connected using DFS
A Comparison Between Spring and Spring Boot
Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence
Fixing 401s with CORS Preflights and Spring Security
Ignore Null Fields with Jackson
CyclicBarrier in Java