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:
Spring Boot with Multiple SQL Import Files
HttpClient 4 Cookbook
Java Program to Implement HashSet API
@Order in Spring
Java Program to Print only Odd Numbered Levels of a Tree
Java Program to Implement First Fit Decreasing for 1-D Objects and M Bins
Check if there is mail waiting
Spring REST API + OAuth2 + Angular (using the Spring Security OAuth legacy stack)
TreeSet và sử dụng Comparable, Comparator trong java
Hướng dẫn kết nối cơ sở dữ liệu với Java JDBC
Java Program to Implement RoleList API
Chuyển đổi giữa các kiểu dữ liệu trong Java
Convert XML to JSON Using Jackson
Java Program to Implement Warshall Algorithm
Java Program to Implement Hash Tables Chaining with List Heads
Hướng dẫn Java Design Pattern – Composite
Java Program to Compute the Area of a Triangle Using Determinants
Java Program to Implement Max-Flow Min-Cut Theorem
Java Program to Implement Ternary Search Algorithm
Java Program to Implement LinkedBlockingQueue API
Creating a Web Application with Spring 5
Iterating over Enum Values in Java
Java Program to Implement Gauss Seidel Method
Mảng (Array) trong Java
Spring Boot Actuator
Spring Security – security none, filters none, access permitAll
Java Collections Interview Questions
Ignore Null Fields with Jackson
An Intro to Spring Cloud Vault
Using the Map.Entry Java Class
Java Program to Implement Graph Coloring Algorithm
Java Program to Find Transpose of a Graph Matrix