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:
Immutable Objects in Java
Spring @RequestParam Annotation
The Modulo Operator in Java
How to Read a Large File Efficiently with 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
JPA/Hibernate Persistence Context
Spring REST API with Protocol Buffers
Hướng dẫn Java Design Pattern – Memento
Prevent Cross-Site Scripting (XSS) in a Spring Application
Java Program to Implement EnumMap API
Generate Spring Boot REST Client with Swagger
Java Program to Implement the Bin Packing Algorithm
Primitive Type Streams in Java 8
Java Program to Find Strongly Connected Components in Graphs
Spring MVC Async vs Spring WebFlux
Runnable vs. Callable in Java
Spring Boot: Customize the Jackson ObjectMapper
Java Program to Find Nearest Neighbor Using Linear Search
Base64 encoding và decoding trong Java 8
HttpClient Basic Authentication
Simple Single Sign-On with Spring Security OAuth2
The Thread.join() Method in Java
Spring Data MongoDB Transactions
Spring Boot - File Handling
Creating a Web Application with Spring 5
Quick Guide to Spring MVC with Velocity
Converting Iterator to List
Java program to Implement Tree Set
Spring WebClient and OAuth2 Support
Guide to Spring Cloud Kubernetes
A Guide to Apache Commons Collections CollectionUtils
Java Program to Implement Branch and Bound Method to Perform a Combinatorial Search