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 Regular Falsi Algorithm
Java Program to Find Whether a Path Exists Between 2 Given Nodes
Java Program to Implement Max Heap
Java Program to Check Whether an Undirected Graph Contains a Eulerian Cycle
Returning Image/Media Data with Spring MVC
HashSet trong Java hoạt động như thế nào?
Spring Boot - Rest Template
Vector trong Java
Hashtable trong java
Java Program to Implement Flood Fill Algorithm
Java Program to Implement Circular Singly Linked List
Concurrent Test Execution in Spring 5
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Java Program to subtract two large numbers using Linked Lists
Call Methods at Runtime Using Java Reflection
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Java Program to Find kth Largest Element in a Sequence
Java Program to Implement Quick Sort with Given Complexity Constraint
Các chương trình minh họa sử dụng Cấu trúc điều khiển trong Java
Lớp Properties trong java
So sánh HashMap và Hashtable trong Java
Java Program to Convert a Decimal Number to Binary Number using Stacks
Java Program to Implement Multi-Threaded Version of Binary Search Tree
Mệnh đề if-else trong java
Java – Write to File
Deploy a Spring Boot WAR into a Tomcat Server
Một số tính năng mới về xử lý ngoại lệ trong Java 7
Spring Boot Annotations
Java Program to Describe the Representation of Graph using Adjacency Matrix
Spring RestTemplate Error Handling
Giới thiệu thư viện Apache Commons Chain
Java Program to Implement Dijkstra’s Algorithm using Priority Queue