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 Array Deque
Java Program to Implement Suffix Tree
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Biến trong java
Arrays.asList vs new ArrayList(Arrays.asList())
Java Program to Perform the Sorting Using Counting Sort
Number Formatting in Java
Handle EML file with JavaMail
Java Program to Implement Fibonacci Heap
Object cloning trong java
HttpClient Timeout
Tránh lỗi NullPointerException trong Java như thế nào?
Working with Kotlin and JPA
Java Program to implement Circular Buffer
Java Program to Implement Tarjan Algorithm
Sử dụng CyclicBarrier trong Java
Spring @RequestMapping New Shortcut Annotations
How to Use if/else Logic in Java 8 Streams
Compare Two JSON Objects with Jackson
Simplify the DAO with Spring and Java Generics
Split a String in Java
Spring Cloud – Bootstrapping
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Recommended Package Structure of a Spring Boot Project
REST Web service: Tạo ứng dụng Java RESTful Client với Jersey Client 2.x
Spring Security OAuth2 – Simple Token Revocation
Java Program to Check Cycle in a Graph using Graph traversal
Java Program to Perform Uniform Binary Search
Shuffling Collections In Java
Spring Boot - Servlet Filter
Java Program to Implement HashTable API
Java Program to Implement Gift Wrapping Algorithm in Two Dimensions