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:
The Dining Philosophers Problem in Java
Java Program to Find the Longest Path in a DAG
Guide to Dynamic Tests in Junit 5
A Guide to WatchService in Java NIO2
Java Program to Implement Ford–Fulkerson Algorithm
Merging Two Maps with Java 8
Java Program to Implement HashTable API
Cài đặt và sử dụng Swagger UI
Java Program to Implement Shell Sort
So sánh HashSet, LinkedHashSet và TreeSet trong Java
Spring 5 Testing with @EnabledIf Annotation
Jackson – Change Name of Field
Spring Cloud AWS – Messaging Support
Giới thiệu Aspect Oriented Programming (AOP)
Tạo chương trình Java đầu tiên sử dụng Eclipse
Spring Security 5 for Reactive Applications
Mockito and JUnit 5 – Using ExtendWith
Java Program to Implement Depth-limited Search
Java Program to Implement Borwein Algorithm
So sánh ArrayList và Vector trong Java
Java Program to Implement Graph Structured Stack
Java Program to Implement Binary Heap
How to Remove the Last Character of a String?
Spring REST API + OAuth2 + Angular
Java Program to Implement Skew Heap
Convert Character Array to String in Java
Programmatic Transaction Management in Spring
Jackson Ignore Properties on Marshalling
Java Program to Implement Euclid GCD Algorithm
Hướng dẫn sử dụng luồng vào ra ký tự trong Java
String Operations with Java Streams
Guide to java.util.concurrent.Future