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:
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Java Program to Perform the Sorting Using Counting Sort
Shuffling Collections In Java
Supplier trong Java 8
Spring MVC Content Negotiation
Collection trong java
Java Program to Find the Longest Path in a DAG
Java Program to Represent Graph Using Incidence List
Java 8 Predicate Chain
Toán tử instanceof trong java
Guava CharMatcher
Basic Authentication with the RestTemplate
Một số từ khóa trong Java
Documenting a Spring REST API Using OpenAPI 3.0
Serverless Functions with Spring Cloud Function
OAuth2 for a Spring REST API – Handle the Refresh Token in Angular
Java Program to Permute All Letters of an Input String
Guide to Guava Table
Java Program to Generate N Number of Passwords of Length M Each
The Registration Process With Spring Security
Java Program to Compute Cross Product of Two Vectors
Cơ chế Upcasting và Downcasting trong java
Spring Boot - Eureka Server
Spring RestTemplate Error Handling
Configure a Spring Boot Web Application
Guide to CopyOnWriteArrayList
Finding the Differences Between Two Lists in Java
Guide to the ConcurrentSkipListMap
How to Convert List to Map in Java
Java Program to Implement Shoelace Algorithm
Using Optional with Jackson
Java Program to Implement HashSet API