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 Find all Forward Edges in a Graph
A Guide to Java HashMap
Java Program to Implement Hash Tree
Updating your Password
Hướng dẫn Java Design Pattern – Command
Rest Web service: Filter và Interceptor với Jersey 2.x (P2)
Java Program to Find Nearest Neighbor for Dynamic Data Set
So sánh HashSet, LinkedHashSet và TreeSet trong Java
Summing Numbers with Java Streams
Java – InputStream to Reader
Java Program to Implement Gaussian Elimination Algorithm
Java Program to Test Using DFS Whether a Directed Graph is Strongly Connected or Not
Quick Intro to Spring Cloud Configuration
Java Program to Check Whether a Directed Graph Contains a Eulerian Path
Java Program to Find the Edge Connectivity of a Graph
Java 8 Stream findFirst() vs. findAny()
So sánh ArrayList và Vector trong Java
Quick Guide to Spring MVC with Velocity
CyclicBarrier in Java
Marker Interface trong Java
Server-Sent Events in Spring
Java Program to Implement Ternary Heap
Spring Boot - Admin Server
Query Entities by Dates and Times with Spring Data JPA
Java Program to Implement Jarvis Algorithm
Hướng dẫn Java Design Pattern – Dependency Injection
Setting a Request Timeout for a Spring REST API
Java Program to Represent Graph Using Adjacency List
Guava CharMatcher
New Features in Java 10
Sắp xếp trong Java 8
Java Program to Implement Hopcroft Algorithm