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:
Converting String to Stream of chars
Hướng dẫn Java Design Pattern – Facade
Concrete Class in Java
A Guide to JPA with Spring
Java Program to Perform Left Rotation on a Binary Search Tree
Spring Boot - Cloud Configuration Client
Từ khóa static và final trong java
Java 8 – Powerful Comparison with Lambdas
Integer Constant Pool trong Java
List Interface trong Java
Jackson Exceptions – Problems and Solutions
Jackson – Change Name of Field
Java Program to Describe the Representation of Graph using Incidence List
Java Program to Implement Max-Flow Min-Cut Theorem
Java Collections Interview Questions
Java Program to Construct an Expression Tree for an Postfix Expression
Java Program to Implement Solovay Strassen Primality Test Algorithm
Java Program to Implement Radix Sort
Hướng dẫn Java Design Pattern – Service Locator
Giới thiệu HATEOAS
Java Program to Implement Gaussian Elimination Algorithm
Marker Interface trong Java
Deque và ArrayDeque trong Java
How to Add a Single Element to a Stream
HashSet trong java
Java Program to Implement Bucket Sort
Java Program to Check if a Directed Graph is a Tree or Not Using DFS
Java Program to Remove the Edges in a Given Cyclic Graph such that its Linear Extension can be Found
Java Program to Implement Heap
Java Program to Show the Duality Transformation of Line and Point
Guide to the ConcurrentSkipListMap
Java Program to Implement Bubble Sort