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 Implement Flood Fill Algorithm
Lớp Collections trong Java (Collections Utility Class)
Java Program to Represent Graph Using Adjacency List
OAuth2 for a Spring REST API – Handle the Refresh Token in Angular
Spring’s RequestBody and ResponseBody Annotations
Java Program to Implement Stack
Ignore Null Fields with Jackson
JWT – Token-based Authentication trong Jersey 2.x
Truyền giá trị và tham chiếu trong java
Spring WebClient Requests with Parameters
Checking for Empty or Blank Strings in Java
Working with Kotlin and JPA
Spring Boot - Rest Template
Guide to the ConcurrentSkipListMap
Java Program to Implement the Schonhage-Strassen Algorithm for Multiplication of Two Numbers
Getting Started with Stream Processing with Spring Cloud Data Flow
Java Program to Implement Expression Tree
Shuffling Collections In Java
HttpAsyncClient Tutorial
Java 8 Collectors toMap
Hướng dẫn Java Design Pattern – Strategy
Spring Cloud – Bootstrapping
Java Program to Implement Knapsack Algorithm
An Intro to Spring Cloud Contract
Arrays.asList vs new ArrayList(Arrays.asList())
Hướng dẫn sử dụng lớp Console trong java
Add Multiple Items to an Java ArrayList
Java Program to Implement the Edmond’s Algorithm for Maximum Cardinality Matching
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Introduction to Spring Cloud OpenFeign
Tiêu chuẩn coding trong Java (Coding Standards)
Java Program to Use Boruvka’s Algorithm to Find the Minimum Spanning Tree