This is a java program to construct a binary tree and perform preorder traversal of the constructed binary tree.
Nodes visited are in the order:
visit Root node
visit Left node
visit Right node
Here is the source code of the Java Program to Perform Preorder 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 pre-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 preorder() { preorder(root); } private void preorder(BinarySearchTreeNodes r) { Stack<BinarySearchTreeNodes> s = new Stack<BinarySearchTreeNodes>(); s.push(r); while (!s.empty()) { r = s.pop(); System.out.print(r.data + " "); if (r.right != null) s.push(r.right); if (r.left != null) s.push(r.left); } } } public class Preorder_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("\nPre order : "); bst.preorder(); scan.close(); } }
Output:
$ javac Preorder_NonRecursive_BST.java $ java Preorder_NonRecursive_BST Enter the first 10 elements of the tree 12 4 10 13 15 46 78 98 45 12 Pre order : 12 4 10 12 13 15 46 45 78 98
Related posts:
Java – File to Reader
Setting Up Swagger 2 with a Spring REST API
Using the Map.Entry Java Class
Java Program to Implement Ford–Fulkerson Algorithm
Java Program to Implement Sieve Of Eratosthenes
Java Program to Implement EnumMap API
Lớp Collections trong Java (Collections Utility Class)
Life Cycle of a Thread in Java
Daemon Threads in Java
Vấn đề Nhà sản xuất (Producer) – Người tiêu dùng (Consumer) và đồng bộ hóa các luồng trong Java
Java Program to Check Multiplicability of Two Matrices
Hướng dẫn Java Design Pattern – Template Method
Hashing a Password in Java
Configuring a DataSource Programmatically in Spring Boot
Spring REST with a Zuul Proxy
Most commonly used String methods in Java
Java Program to Implement Red Black Tree
Java Program to Implement Kosaraju Algorithm
Java Program to Implement Gauss Jordan Elimination
Spring Boot - Application Properties
The DAO with JPA and Spring
Spring WebClient vs. RestTemplate
Java Program to Implement Weight Balanced Tree
Java Program to Implement VList
Spring Boot Integration Testing with Embedded MongoDB
An Intro to Spring Cloud Security
Spring Boot - Batch Service
How to Find an Element in a List with Java
Spring AMQP in Reactive Applications
Guava Collections Cookbook
Java Program to Perform Searching Using Self-Organizing Lists
Sort a HashMap in Java