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 Quick Sort with Given Complexity Constraint
Java List UnsupportedOperationException
Các kiểu dữ liệu trong java
Hướng dẫn Java Design Pattern – Interpreter
Java Program to Implement Direct Addressing Tables
The StackOverflowError in Java
Java Program to Compute Discrete Fourier Transform Using Naive Approach
Java Program to Implement Shunting Yard Algorithm
Java Program to Implement LinkedBlockingDeque API
Java Program to Check whether Undirected Graph is Connected using BFS
Java Program to Use rand and srand Functions
Một số ký tự đặc biệt trong Java
Java Program to Implement Patricia Trie
How to Get a Name of a Method Being Executed?
Java Program to Implement Quick Sort Using Randomization
Compact Strings in Java 9
Java Program to implement Sparse Vector
How to Change the Default Port in Spring Boot
Converting between an Array and a List in Java
A Guide to BitSet in Java
Guide to java.util.concurrent.Future
New Features in Java 10
Guava CharMatcher
Toán tử trong java
Guide to the Java TransferQueue
Java Program for Douglas-Peucker Algorithm Implementation
Abstract class và Interface trong Java
“Stream has already been operated upon or closed” Exception in Java
Java String Conversions
LIKE Queries in Spring JPA Repositories
Java Program to Find Minimum Element in an Array using Linear Search
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)