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:
Phân biệt JVM, JRE, JDK
Jackson Ignore Properties on Marshalling
How to Return 404 with Spring WebFlux
Request a Delivery / Read Receipt in Javamail
Introduction to Eclipse Collections
Java Program to Implement Hash Tables Chaining with List Heads
Spring Security – security none, filters none, access permitAll
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
An Intro to Spring Cloud Zookeeper
Hướng dẫn Java Design Pattern – Singleton
Java Program to Implement Randomized Binary Search Tree
Guava – Join and Split Collections
Java Program to Implement SynchronosQueue API
Converting Iterator to List
Test a REST API with Java
Disable DNS caching
Java Program to Implement the Vigenere Cypher
Spring WebClient Filters
Removing all Nulls from a List in Java
Java Program to Implement Trie
A Quick Guide to Spring MVC Matrix Variables
Spring MVC and the @ModelAttribute Annotation
Java Program to Implement Queue using Linked List
Java Program to Find Nearest Neighbor Using Linear Search
Java Program to Implement ConcurrentLinkedQueue API
Mockito and JUnit 5 – Using ExtendWith
Using a Mutex Object in Java
So sánh ArrayList và Vector trong Java
Java Program to Find the Shortest Path Between Two Vertices Using Dijkstra’s Algorithm
Function trong Java 8
Lập trình đa luồng trong Java (Java Multi-threading)
An Intro to Spring Cloud Security