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:
Handling Errors in Spring WebFlux
Bootstrap a Web Application with Spring 5
Java Program to Check whether Directed Graph is Connected using DFS
Inheritance with Jackson
JUnit 5 for Kotlin Developers
Basic Authentication with the RestTemplate
Quick Guide to Spring Bean Scopes
Cơ chế Upcasting và Downcasting trong java
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Simplify the DAO with Spring and Java Generics
Giới thiệu Google Guice – Dependency injection (DI) framework
Lập trình đa luồng với CompletableFuture trong Java 8
How to Remove the Last Character of a String?
Java Web Services – JAX-WS – SOAP
Get and Post Lists of Objects with RestTemplate
A Guide to the finalize Method in Java
@DynamicUpdate with Spring Data JPA
Spring WebClient Requests with Parameters
Jackson – Unmarshall to Collection/Array
The Thread.join() Method in Java
Java Multi-line String
Exploring the New Spring Cloud Gateway
How to Break from Java Stream forEach
HttpClient 4 Cookbook
Java Program to Implement Stack using Linked List
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle
Java Program to Implement Gauss Seidel Method
Java Program to Check Whether Graph is DAG
Functional Interface trong Java 8
Giới thiệu Json Web Token (JWT)
Cài đặt và sử dụng Swagger UI