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:
Spring Security and OpenID Connect
Hướng dẫn Java Design Pattern – Flyweight
Most commonly used String methods in Java
Spring Webflux and CORS
Java Program to Implement Gauss Jordan Elimination
Spring Webflux with Kotlin
Java Program to Implement Coppersmith Freivald’s Algorithm
Java Program to Implement Bubble Sort
Using JWT with Spring Security OAuth (legacy stack)
Map to String Conversion in Java
A Custom Media Type for a Spring REST API
Test a REST API with Java
Encode a String to UTF-8 in Java
So sánh ArrayList và Vector trong Java
Spring Boot - Exception Handling
Java Program to Implement Aho-Corasick Algorithm for String Matching
Java Program to Perform Left Rotation on a Binary Search Tree
Apache Camel with Spring Boot
Hướng dẫn Java Design Pattern – Chain of Responsibility
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Iterating over Enum Values in Java
Adding a Newline Character to a String in Java
Java Program to Perform integer Partition for a Specific Case
Hướng dẫn Java Design Pattern – Iterator
Tìm hiểu về Web Service
File Upload with Spring MVC
Giới thiệu Design Patterns
DynamoDB in a Spring Boot Application Using Spring Data
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
Java 9 Stream API Improvements
Spring Cloud AWS – S3
Spring Security OAuth2 – Simple Token Revocation
 
