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:
Chương trình Java đầu tiên
Converting Strings to Enums in Java
Java Program to Implement Graph Structured Stack
Lập trình mạng với java
Spring’s RequestBody and ResponseBody Annotations
Batch Processing with Spring Cloud Data Flow
Spring Boot Security Auto-Configuration
Java Program to Implement Bresenham Line Algorithm
The DAO with Spring and Hibernate
Spring Cloud AWS – RDS
Java Program to Perform Encoding of a Message Using Matrix Multiplication
Guide to @ConfigurationProperties in Spring Boot
Getting Started with GraphQL and Spring Boot
A Guide to Java HashMap
Get the workstation name or IP
Immutable ArrayList in Java
Java Program to Implement Iterative Deepening
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Check If Two Lists are Equal in Java
Java Program to Implement Booth Algorithm
Spring Boot - Batch Service
Tính đóng gói (Encapsulation) trong java
New Features in Java 14
Spring’s RequestBody and ResponseBody Annotations
Format ZonedDateTime to String
Creating a Web Application with Spring 5
Consuming RESTful Web Services
Hướng dẫn Java Design Pattern – Facade
Java Stream Filter with Lambda Expression
Validate email address exists or not by Java Code
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Getting Started with Custom Deserialization in Jackson