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:
Count Occurrences of a Char in a String
Bootstrap a Web Application with Spring 5
Sort a HashMap in Java
Serve Static Resources with Spring
Allow user:password in URL
Spring Boot - Rest Controller Unit Test
Java Program to Find Path Between Two Nodes in a Graph
Spring MVC and the @ModelAttribute Annotation
Converting Between a List and a Set in Java
Simple Single Sign-On with Spring Security OAuth2
Java Program to Implement Bucket Sort
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Lớp Collectors trong Java 8
Java Program to Implement Weight Balanced Tree
Creating a Generic Array in Java
Anonymous Classes in Java
Java Program to Implement CopyOnWriteArraySet API
Java Program to Represent Graph Using Adjacency Matrix
Hướng dẫn Java Design Pattern – Abstract Factory
Java Program to Compute DFT Coefficients Directly
Java – Rename or Move a File
Notify User of Login From New Device or Location
Java Program to Implement Brent Cycle Algorithm
Spring Boot - Cloud Configuration Client
Java Program to Compute the Area of a Triangle Using Determinants
Spring Boot - Sending Email
Java Program to Implement Adjacency List
Java Program to Solve a Matching Problem for a Given Specific Case
Spring 5 and Servlet 4 – The PushBuilder
Java Program to Implement Find all Cross Edges in a Graph
Spring Data MongoDB Transactions
Object cloning trong java