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:
Giới thiệu Google Guice – Dependency injection (DI) framework
Introduction to Spring Data JDBC
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
Converting Between a List and a Set in Java
Finding the Differences Between Two Lists in Java
A Guide to Iterator in Java
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Convert Hex to ASCII in Java
Immutable ArrayList in Java
Add Multiple Items to an Java ArrayList
New in Spring Security OAuth2 – Verify Claims
Guide to Spring 5 WebFlux
REST Web service: Upload và Download file với Jersey 2.x
Java Program to Implement Meldable Heap
Consuming RESTful Web Services
Copy a List to Another List in Java
Jackson – Bidirectional Relationships
Generate Spring Boot REST Client with Swagger
Java Program to Implement Park-Miller Random Number Generation Algorithm
Merging Streams in Java
Simplify the DAO with Spring and Java Generics
The Guide to RestTemplate
Quick Guide to Spring Bean Scopes
Guide to @JsonFormat in Jackson
Spring Data MongoDB – Indexes, Annotations and Converters
Spring Boot - Securing Web Applications
Java Program to Perform Optimal Paranthesization Using Dynamic Programming
Java Program to Implement Aho-Corasick Algorithm for String Matching
Java Program to Implement Binary Search Tree
Receive email using POP3
Java Program to Implement TreeSet API
Spring Boot - Apache Kafka