This is a java program to construct a binary tree and perform preorder traversal of the constructed binary tree.
Nodes visited are in the order:
visit Root node
visit Left node
visit Right node
Here is the source code of the Java Program to Perform Preorder 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 preorder 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 preorder() { preorder(root); } private void preorder(BinarySearchTreeNodes r) { if (r != null) { System.out.print(r.getData() + " "); preorder(r.getLeft()); preorder(r.getRight()); } } } public class Preorder_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("\nPre order : "); bst.preorder(); scan.close(); } }
Output:
$ javac Preorder_Recursive_BST.java $ java Preorder_Recursive_BST Enter the first 10 elements of the tree 12 10 11 03 15 19 02 01 04 70 Pre order : 12 10 3 2 1 4 11 15 19 70
Related posts:
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
Guide to the Java Queue Interface
Java Program to Implement Floyd Cycle Algorithm
Using Custom Banners in Spring Boot
Java Program to Check whether Directed Graph is Connected using BFS
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Disable DNS caching
Spring Cloud AWS – EC2
A Quick Guide to Spring MVC Matrix Variables
Spring Data JPA @Modifying Annotation
Spring @Primary Annotation
Java Program to Find Inverse of a Matrix
How to Kill a Java Thread
Java Program to Perform Partial Key Search in a K-D Tree
Java Program to implement Priority Queue
LinkedHashSet trong Java hoạt động như thế nào?
Spring WebClient Filters
Comparing getPath(), getAbsolutePath(), and getCanonicalPath() in Java
Java Program to Search for an Element in a Binary Search Tree
Check If a String Is Numeric in Java
Changing Annotation Parameters At Runtime
Java Program to Implement Max Heap
Spring Boot - Sending Email
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Java Program to Perform the Sorting Using Counting Sort
Java Program to Perform Naive String Matching
Custom Error Pages with Spring MVC
Sắp xếp trong Java 8
Java Program to Implement Caesar Cypher
Spring Autowiring of Generic Types
Guide to Guava Table
Simple Single Sign-On with Spring Security OAuth2