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 Program to Implement Best-First Search
Guide to Java OutputStream
Introduction to Spliterator in Java
Jackson Date
Supplier trong Java 8
Autoboxing và Unboxing trong Java
Chuyển đổi Array sang ArrayList và ngược lại
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
An Introduction to ThreadLocal in Java
Java Program to Check Whether it is Weakly Connected or Strongly Connected for a Directed Graph
Spring MVC and the @ModelAttribute Annotation
Java Program to Compute Cross Product of Two Vectors
Serve Static Resources with Spring
Examine the internal DNS cache
Java Program to Solve Tower of Hanoi Problem using Stacks
Using a Mutex Object in Java
Hướng dẫn Java Design Pattern – Iterator
Spring Security – security none, filters none, access permitAll
Hướng dẫn sử dụng Java String, StringBuffer và StringBuilder
How to Implement Caching using Adonis.js 5
Primitive Type Streams in Java 8
Xây dựng ứng dụng Client-Server với Socket trong Java
Java Program to Generate a Graph for a Given Fixed Degree Sequence
Spring Security Authentication Provider
Spring Boot - Thymeleaf
Loại bỏ các phần tử trùng trong một ArrayList như thế nào?
Reversing a Linked List in Java
Converting between an Array and a List in Java
HandlerAdapters in Spring MVC
An Introduction to Java.util.Hashtable Class
Hướng dẫn Java Design Pattern – Composite
Java Program to Implement the Checksum Method for Small String Messages and Detect