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 Check whether Graph is a Bipartite using 2 Color Algorithm
Use Liquibase to Safely Evolve Your Database Schema
Java Timer
Quick Guide on Loading Initial Data with Spring Boot
Merging Streams in Java
Java Program to Solve a Matching Problem for a Given Specific Case
Java Program to Create a Random Graph Using Random Edge Generation
Spring Data – CrudRepository save() Method
Java – InputStream to Reader
Java Program to implement Bit Set
Hướng dẫn Java Design Pattern – Memento
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
Java Optional as Return Type
Java Program to Implement Regular Falsi Algorithm
Java Program to Check whether Graph is a Bipartite using DFS
Java Program to Describe the Representation of Graph using Incidence Matrix
Posting with HttpClient
Comparing Objects in Java
How to Get All Spring-Managed Beans?
Spring Boot - Zuul Proxy Server and Routing
Giới thiệu JDBC Connection Pool
Java Program to Implement Merge Sort Algorithm on Linked List
Collect a Java Stream to an Immutable Collection
Java Program to Implement Triply Linked List
REST Web service: Basic Authentication trong Jersey 2.x
Java Program to subtract two large numbers using Linked Lists
Java – Write to File
Entity To DTO Conversion for a Spring REST API
HttpClient Connection Management
Guide to DelayQueue
Send email with SMTPS (eg. Google GMail)
Inject Parameters into JUnit Jupiter Unit Tests