This is a java program to construct a binary tree and perform preorder traversal of the constructed binary tree.
Nodes visited are in the order:
visit Root node
visit Left node
visit Right node
Here is the source code of the Java Program to Perform Preorder 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 preorder 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 preorder()
{
preorder(root);
}
private void preorder(BinarySearchTreeNodes r)
{
if (r != null)
{
System.out.print(r.getData() + " ");
preorder(r.getLeft());
preorder(r.getRight());
}
}
}
public class Preorder_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("\nPre order : ");
bst.preorder();
scan.close();
}
}
Output:
$ javac Preorder_Recursive_BST.java $ java Preorder_Recursive_BST Enter the first 10 elements of the tree 12 10 11 03 15 19 02 01 04 70 Pre order : 12 10 3 2 1 4 11 15 19 70
Related posts:
Java Program to Implement Hash Tables with Linear Probing
Java Program to Perform Encoding of a Message Using Matrix Multiplication
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
Thao tác với tập tin và thư mục trong Java
Converting Between a List and a Set in Java
Spring Boot - Creating Docker Image
New in Spring Security OAuth2 – Verify Claims
Service Registration with Eureka
Mapping a Dynamic JSON Object with Jackson
Java Program to Implement Gauss Seidel Method
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Java Program to Implement the Hungarian Algorithm for Bipartite Matching
Converting Between an Array and a Set in Java
Java Program to Find Transpose of a Graph Matrix
JWT – Token-based Authentication trong Jersey 2.x
Spring Boot - Admin Client
Java Program to Check Whether Topological Sorting can be Performed in a Graph
Handling URL Encoded Form Data in Spring REST
Toán tử trong java
Comparing Two HashMaps in Java
Function trong Java 8
Functional Interfaces in Java 8
Java Program to Compute DFT Coefficients Directly
Java Program to Implement Hash Tables Chaining with List Heads
Java Program to Encode a Message Using Playfair Cipher
Hướng dẫn Java Design Pattern – Prototype
How to Break from Java Stream forEach
Java Program to Represent Graph Using Linked List
Introduction to Thread Pools in Java
HttpClient 4 Cookbook
Hướng dẫn Java Design Pattern – Decorator
Introduction to Spring Cloud OpenFeign