This is a java program to construct a binary tree and perform in-order traversal of the constructed binary tree.
Nodes visited are in the order:
visit Left node
visit Root node
visit Right node
Here is the source code of the Java Program to Perform Inorder Non-Recursive Traversal of a Given 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 non recursive in order traversal of Binary Search Tree import java.util.Scanner; import java.util.Stack; class BinarySearchTreeNode { BinarySearchTreeNode left, right; int data; public BinarySearchTreeNode() { left = null; right = null; data = 0; } public BinarySearchTreeNode(int n) { left = null; right = null; data = n; } public void setLeft(BinarySearchTreeNode n) { left = n; } public void setRight(BinarySearchTreeNode n) { right = n; } public BinarySearchTreeNode getLeft() { return left; } public BinarySearchTreeNode getRight() { return right; } public void setData(int d) { data = d; } public int getData() { return data; } } class BinarySearchTreeOperations { private BinarySearchTreeNodes root; public BinarySearchTreeOperations() { 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 inorder() { inorder(root); } private void inorder(BinarySearchTreeNodes r) { if (r == null) return; Stack<BinarySearchTreeNodes> stack = new Stack<BinarySearchTreeNodes>(); while (!stack.isEmpty() || r != null) { if (r != null) { stack.push(r); r = r.left; } else { r = stack.pop(); System.out.print(r.data + " "); r = r.right; } } } } public class Inorder_NonRecursive_BST { public static void main(String[] args) { Scanner scan = new Scanner(System.in); BinarySearchTreeOperations bst = new BinarySearchTreeOperations(); 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("\nIn order : "); bst.inorder(); scan.close(); } }
Output:
$ javac Inorder_NonRecursive_BST.java $ java Inorder_NonRecursive_BST Enter the first 10 elements of the tree 12 4 10 13 15 46 78 98 45 12 In order : 4 10 12 12 13 15 45 46 78 98
Related posts:
Java Program to Implement Ford–Fulkerson Algorithm
Convert char to String in Java
Inheritance and Composition (Is-a vs Has-a relationship) in Java
Java Program to Implement Binary Tree
How To Serialize and Deserialize Enums with Jackson
Template Engines for Spring
So sánh HashMap và HashSet trong Java
Java Program to Implement ArrayBlockingQueue API
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
How to Read a Large File Efficiently with Java
Spring Data JPA Delete and Relationships
List Interface trong Java
Convert Hex to ASCII in Java
Hướng dẫn Java Design Pattern – State
Converting String to Stream of chars
Java Program to Implement Fermat Factorization Algorithm
Java Program to Implement Double Order Traversal of a Binary Tree
Injecting Prototype Beans into a Singleton Instance in Spring
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Java Program to Implement ConcurrentSkipListMap API
Chuyển đổi từ HashMap sang ArrayList
Spring 5 Functional Bean Registration
LIKE Queries in Spring JPA Repositories
Guide to BufferedReader
Converting Strings to Enums in Java
Java Program to Implement Lloyd’s Algorithm
Java Program to Find Nearest Neighbor Using Linear Search
Test a REST API with Java
ThreadPoolTaskExecutor corePoolSize vs. maxPoolSize
Automatic Property Expansion with Spring Boot
Command-Line Arguments in Java
Autoboxing và Unboxing trong Java