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:
Logging in Spring Boot
Guide to @JsonFormat in Jackson
Sorting in Java
Phân biệt JVM, JRE, JDK
Java Program to Implement Ford–Fulkerson Algorithm
Java Program to Implement Disjoint Set Data Structure
Logging a Reactive Sequence
Hướng dẫn sử dụng Java Annotation
Java Program to Check Whether Topological Sorting can be Performed in a Graph
Custom JUnit 4 Test Runners
Java Program to Implement Variable length array
Hướng dẫn Java Design Pattern – Interpreter
Login For a Spring Web App – Error Handling and Localization
Partition a List in Java
Java Program to Solve the 0-1 Knapsack Problem
Transaction Propagation and Isolation in Spring @Transactional
Reversing a Linked List in Java
Cài đặt và sử dụng Swagger UI
Check If Two Lists are Equal in Java
Java Program to Represent Graph Using Incidence Matrix
Spring Data – CrudRepository save() Method
A Guide to Java SynchronousQueue
Sử dụng CyclicBarrier trong Java
Tạo ứng dụng Java RESTful Client với thư viện OkHttp
Java Program to Implement Fenwick Tree
Java Program to Check whether Directed Graph is Connected using BFS
Circular Dependencies in Spring
Collection trong java
Notify User of Login From New Device or Location
Java Program to implement Bi Directional Map
LinkedHashSet trong java
Java Program to Find Maximum Element in an Array using Binary Search