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 Ternary Search Algorithm
Spring Boot: Customize the Jackson ObjectMapper
A Guide to Java HashMap
Spring Boot - Building RESTful Web Services
Spring Boot - Cloud Configuration Client
Java Program to Implement Karatsuba Multiplication Algorithm
Guide to the Java ArrayList
Biến trong java
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Hướng dẫn Java Design Pattern – Template Method
Hướng dẫn Java Design Pattern – Interpreter
Spring REST API + OAuth2 + Angular
Java Program to Find a Good Feedback Vertex Set
Java Program to Implement Tarjan Algorithm
Intro to Inversion of Control and Dependency Injection with Spring
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Java Program to Implement Dijkstra’s Algorithm using Set
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Java Program to Implement AttributeList API
An Intro to Spring Cloud Task
Convert Hex to ASCII in Java
Java Program to Check Whether a Given Point is in a Given Polygon
Java Program to Implement Min Heap
Java Program to Implement Find all Forward Edges in a Graph
Java Program to implement Sparse Vector
A Guide to the Java LinkedList
Instance Profile Credentials using Spring Cloud
Spring Boot Annotations
Rest Web service: Filter và Interceptor với Jersey 2.x (P2)
Java Program to Implement Ford–Fulkerson Algorithm
Java Program to Perform Polygon Containment Test
Simultaneous Spring WebClient Calls