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:
Java Program to Implement Fenwick Tree
Check If a File or Directory Exists in Java
Wiring in Spring: @Autowired, @Resource and @Inject
Creating a Generic Array in Java
Zipping Collections in Java
Guide to DelayQueue
@Lookup Annotation in Spring
Java Program to Check if it is a Sparse Matrix
Java Program to Implement HashTable API
wait() and notify() Methods in Java
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
Introduction to Spring Cloud Netflix – Eureka
Java equals() and hashCode() Contracts
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Daemon Threads in Java
Java Program to Solve the Fractional Knapsack Problem
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
A Guide to Java HashMap
Send an email using the SMTP protocol
Java Program to Solve Set Cover Problem assuming at max 2 Elements in a Subset
ClassNotFoundException vs NoClassDefFoundError
Java Program to Perform Partial Key Search in a K-D Tree
Java Program to Perform Addition Operation Using Bitwise Operators
Spring MVC Content Negotiation
Java Program to Implement Find all Cross Edges in a Graph
Java Program to Find the Peak Element of an Array O(n) time (Naive Method)
Java Program to Implement VList
Spring Boot Application as a Service
Java Program to Perform String Matching Using String Library
Java – Reader to Byte Array
Java Program to Implement Leftist Heap
Lấy ngày giờ hiện tại trong Java