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 Queue
New Features in Java 9
Spring Security Remember Me
Java Program to Perform Uniform Binary Search
An Example of Load Balancing with Zuul and Eureka
Apache Commons Collections SetUtils
Java Program for Topological Sorting in Graphs
Java Program to Implement Levenshtein Distance Computing Algorithm
Java NIO2 Path API
Java 8 Stream findFirst() vs. findAny()
Java Program to Implement an Algorithm to Find the Global min Cut in a Graph
Spring Boot - Securing Web Applications
Java Program to Perform Searching Using Self-Organizing Lists
OAuth2 Remember Me with Refresh Token
Java Program to Find the Number of Ways to Write a Number as the Sum of Numbers Smaller than Itself
Apache Camel with Spring Boot
Hướng dẫn Java Design Pattern – Intercepting Filter
Giới thiệu SOAP UI và thực hiện test Web Service
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Login For a Spring Web App – Error Handling and Localization
Java Program to Check whether Graph is Biconnected
Derived Query Methods in Spring Data JPA Repositories
Hướng dẫn Java Design Pattern – Transfer Object
Spring Boot Change Context Path
How to Replace Many if Statements in Java
Java Program to Implement the Hungarian Algorithm for Bipartite Matching
Collection trong java
How to Read a File in Java
Java Program to Implement Fisher-Yates Algorithm for Array Shuffling
Từ khóa static và final trong java
So sánh HashMap và HashSet trong Java
CharSequence vs. String in Java