Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree

This is a java program to construct a binary tree and perform postorder traversal of the constructed binary tree.
Nodes visited are in the order:
visit Left node
visit Right node
visit Root node

Here is the source code of the Java Program to Perform Postorder 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 postorder 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 postorder()
    {
        postorder(root);
    }
 
    private void postorder(BinarySearchTreeNodes r)
    {
        if (r != null)
        {
            postorder(r.getLeft());
            postorder(r.getRight());
            System.out.print(r.getData() + " ");
        }
    }
}
 
public class Postorder_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("\nPost order : ");
        bst.postorder();
 
        scan.close();
    }
}

Output:

$ javac Postorder_Recursive_BST.java
$ java Postorder_Recursive_BST
 
Enter the first 10 elements of the tree
 
12 10 11 03 15 19 02 01 04 70
 
Post order : 1 2 4 3 11 10 70 19 15 12

Related posts:

Join and Split Arrays and Collections in Java
Converting Strings to Enums in Java
Converting Between Byte Arrays and Hexadecimal Strings in Java
Extract links from an HTML page
Hướng dẫn Java Design Pattern – Prototype
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
Java Program to Find Inverse of a Matrix
Java Program to Perform Partial Key Search in a K-D Tree
Java Program to do a Depth First Search/Traversal on a graph non-recursively
Exploring the New Spring Cloud Gateway
Updating your Password
Spring Boot - Cloud Configuration Server
Java – Write a Reader to File
So sánh ArrayList và Vector trong Java
Spring RestTemplate Error Handling
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
Một số từ khóa trong Java
Hướng dẫn Java Design Pattern – Proxy
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Java Program to Find kth Largest Element in a Sequence
Phương thức tham chiếu trong Java 8 – Method References
A Guide to Spring Cloud Netflix – Hystrix
Java Program to Find a Good Feedback Edge Set in a Graph
Java Program to Implement Gabow Algorithm
Java Program to Find the Vertex Connectivity of a Graph
Java Program to Implement Ternary Tree
Server-Sent Events in Spring
Creating a Custom Starter with Spring Boot
Converting Between a List and a Set in Java
Java Program to Find Location of a Point Placed in Three Dimensions Using K-D Trees
Transaction Propagation and Isolation in Spring @Transactional
Java Program to Implement the Edmond’s Algorithm for Maximum Cardinality Matching