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 equals() and hashCode() Contracts
Remove HTML tags from a file to extract only the TEXT
Mix plain text and HTML content in a mail
Quick Guide to the Java StringTokenizer
Quick Guide to Spring MVC with Velocity
Converting String to Stream of chars
Java Switch Statement
Hướng dẫn Java Design Pattern – Null Object
Java Program to Create the Prufer Code for a Tree
Java Program to Perform the Shaker Sort
Java Program to Implement VList
Convert Character Array to String in Java
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
HttpClient Basic Authentication
Introduction to Thread Pools in Java
Java Program to Find the Connected Components of an UnDirected Graph
Java Program to Implement LinkedBlockingDeque API
Convert String to Byte Array and Reverse in Java
Netflix Archaius with Various Database Configurations
Java Program to Implement the Hill Cypher
Spring Cloud – Adding Angular
Java Program to Implement Find all Back Edges in a Graph
Java Program to Evaluate an Expression using Stacks
Properties with Spring and Spring Boot
Java Program to Implement the Hungarian Algorithm for Bipartite Matching
Java Program to Implement Ternary Search Tree
Create Java Applet to Simulate Any Sorting Technique
Initialize a HashMap in Java
Logging in Spring Boot
HttpClient with SSL
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
Java Program to Perform Postorder Non-Recursive Traversal of a Given Binary Tree