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 – Delete a File
A Guide to ConcurrentMap
Java CyclicBarrier vs CountDownLatch
Java Program to Describe the Representation of Graph using Incidence Matrix
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Spring Boot - Thymeleaf
An Intro to Spring Cloud Security
Java Program to Generate All Subsets of a Given Set in the Gray Code Order
Spring Boot Configuration with Jasypt
Updating your Password
MyBatis with Spring
Ép kiểu trong Java (Type casting)
Java Program to Find Maximum Element in an Array using Binary Search
Hướng dẫn Java Design Pattern – Memento
DistinctBy in the Java Stream API
Testing an OAuth Secured API with Spring MVC
Lớp lồng nhau trong java (Java inner class)
Using Java Assertions
Java 8 StringJoiner
Spring Boot Change Context Path
Java Program to Implement Pagoda
Tìm hiểu về xác thực và phân quyền trong ứng dụng
Java Program to Implement Ford–Fulkerson Algorithm
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
A Guide to LinkedHashMap in Java
Spring Boot - Introduction
Convert Hex to ASCII in Java
Quick Intro to Spring Cloud Configuration
Check If Two Lists are Equal in Java
Java Program to Perform the Sorting Using Counting Sort
Java Program to Represent Graph Using Adjacency List
Java Scanner hasNext() vs. hasNextLine()