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 Branch and Bound Method to Perform a Combinatorial Search
Database Migrations with Flyway
Java Program to Implement Solovay Strassen Primality Test Algorithm
Spring Boot - CORS Support
Java InputStream to String
The Difference Between map() and flatMap()
Spring Boot - Flyway Database
Java – Write a Reader to File
Java Program to Implement K Way Merge Algorithm
Introduction to the Functional Web Framework in Spring 5
How To Serialize and Deserialize Enums with Jackson
Error Handling for REST with Spring
Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Java Program to Implement D-ary-Heap
Hướng dẫn Java Design Pattern – Decorator
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
A Guide to JPA with Spring
Spring Cloud Connectors and Heroku
Java – Byte Array to Reader
A Guide to the Java LinkedList
Debug a JavaMail Program
Derived Query Methods in Spring Data JPA Repositories
LinkedHashSet trong Java hoạt động như thế nào?
Display Auto-Configuration Report in Spring Boot
Toán tử trong java
Pagination and Sorting using Spring Data JPA
Java Program to Implement Stack API
Java Timer
Transaction Propagation and Isolation in Spring @Transactional
Java Program to Generate Random Hexadecimal Byte
Java NIO2 Path API