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 Aho-Corasick Algorithm for String Matching
Spring Boot - Internationalization
Query Entities by Dates and Times with Spring Data JPA
Java Program to Implement LinkedBlockingDeque API
Quick Guide to Spring Controllers
Java Program to Implement D-ary-Heap
A Custom Data Binder in Spring MVC
Quick Guide to the Java StringTokenizer
Spring RestTemplate Request/Response Logging
Java program to Implement Tree Set
Hướng dẫn Java Design Pattern – Strategy
Logging in Spring Boot
Java Program to Perform String Matching Using String Library
Toán tử instanceof trong java
Java Program to Implement Graph Structured Stack
How to Break from Java Stream forEach
Refactoring Design Pattern với tính năng mới trong Java 8
Java Program to Implement Caesar Cypher
Java Program to Implement the Vigenere Cypher
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Spring Boot: Customize Whitelabel Error Page
Java Stream Filter with Lambda Expression
Kiểu dữ liệu Ngày Giờ (Date Time) trong java
Java Program to Use Dynamic Programming to Solve Approximate String Matching
Guide to @JsonFormat in Jackson
So sánh ArrayList và LinkedList trong Java
Sử dụng CountDownLatch trong Java
Generic Constructors in Java
Creating a Custom Starter with Spring Boot
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Java Program to Implement CopyOnWriteArraySet API
Java Program to Check whether Undirected Graph is Connected using BFS