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 Priority Queue
Java Program to Implement Knapsack Algorithm
Spring Boot - Runners
Một số nguyên tắc, định luật trong lập trình
Convert String to int or Integer in Java
Immutable ArrayList in Java
Java Program to Find Basis and Dimension of a Matrix
Từ khóa throw và throws trong Java
Java Program to Find Minimum Number of Edges to Cut to make the Graph Disconnected
Java Program to do a Breadth First Search/Traversal on a graph non-recursively
Java Program to Find the Minimum value of Binary Search Tree
Check if a String is a Palindrome in Java
Migrating from JUnit 4 to JUnit 5
A Quick Guide to Spring MVC Matrix Variables
Java Program to Permute All Letters of an Input String
Java Program to Implement Miller Rabin Primality Test Algorithm
HashMap trong Java hoạt động như thế nào?
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Spring Boot - Tracing Micro Service Logs
Ignore Null Fields with Jackson
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Transactions with Spring and JPA
OAuth2 for a Spring REST API – Handle the Refresh Token in Angular
Spring Boot - CORS Support
Spring Data JPA and Null Parameters
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Java Program to Implement Sieve Of Eratosthenes
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Introduction to Thread Pools in Java
Java Program to Implement RenderingHints API
Encode/Decode to/from Base64
A Guide to LinkedHashMap in Java