This is a Java Program to perform Double Order traversal over binary tree.
Recurse through:
1. Visit root of (sub)tree.
2. Visit left sub-tree.
3. Revisit root of (sub)tree.
4. Visit right sub-tree.
Here is the source code of the Java Program to Implement Double Order Traversal of a 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 doubleorder 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 doubleorder()
{
doubleorder(root);
}
private void doubleorder(BinarySearchTreeNodes r)
{
if(r != null)
{
System.out.print(r.getData() + " ");
doubleorder(r.getLeft());
System.out.print(r.getData() + " ");
doubleorder(r.getRight());
}
}
}
public class Doubleorder_Traversal
{
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("\nDouble-order : ");
bst.doubleorder();
scan.close();
}
}
Output:
$ javac Doubleorder_Traversal.java $ java Doubleorder_Traversal Enter the first 10 elements of the tree 12 10 11 03 15 19 02 01 04 70 Double-order : 12 10 3 2 1 1 2 3 4 4 10 11 11 12 15 15 19 19 70 70
Related posts:
Java Streams vs Vavr Streams
Java Program to Find a Good Feedback Edge Set in a Graph
Validations for Enum Types
Guide to Escaping Characters in Java RegExps
Lập trình đa luồng với CompletableFuture trong Java 8
New Features in Java 13
Add Multiple Items to an Java ArrayList
Java Program to Perform the Shaker Sort
Java Program to Implement Queue using Two Stacks
Spring RestTemplate Error Handling
Java Program to Implement Ternary Tree
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Java Program to Implement Binary Heap
Recommended Package Structure of a Spring Boot Project
Using the Not Operator in If Conditions in Java
Introduction to Java Serialization
Java Program to Implement Insertion Sort
Hướng dẫn sử dụng String Format trong Java
Set Interface trong Java
Spring Data MongoDB Transactions
Refactoring Design Pattern với tính năng mới trong Java 8
HashMap trong Java hoạt động như thế nào?
Removing Elements from Java Collections
Java Program to Generate All Possible Combinations Out of a, b, c, d, e
Auditing with JPA, Hibernate, and Spring Data JPA
An Example of Load Balancing with Zuul and Eureka
Spring Data MongoDB – Indexes, Annotations and Converters
Serve Static Resources with Spring
A Guide to TreeMap in Java
Java Program for Topological Sorting in Graphs
Java Program to Implement vector
Java Program to Implement Vector API