This is a Java Program to implement a Binary Tree and print the level order traversal of the same, such that only odd levels are considered. At current level check nodes in next to next level and put them in Queue, dequeue them one by one and print them.
Here is the source code of the Java Program to Print only Odd Numbered Levels of a 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 print only odd levels of the given tree
import java.util.Queue;
import java.util.LinkedList;
public class BinaryTreePrintOddLevels
{
private static class Node<T>
{
public Node<T> left;
public Node<T> right;
public T data;
public Node(T data)
{
this.data = data;
}
public Node<T> getLeft()
{
return this.left;
}
public void setLeft(Node<T> left)
{
this.left = left;
}
public Node<T> getRight()
{
return this.right;
}
public void setRight(Node<T> right)
{
this.right = right;
}
}
public static void preorder(Node<?> n)
{
if (n != null)
{
System.out.print(n.data + " ");
preorder(n.getLeft());
preorder(n.getRight());
}
}
public static void inorder(Node<?> n)
{
if (n != null)
{
inorder(n.getLeft());
System.out.print(n.data + " ");
inorder(n.getRight());
}
}
public static void postorder(Node<?> n)
{
if (n != null)
{
postorder(n.getLeft());
postorder(n.getRight());
System.out.print(n.data + " ");
}
}
public static void levelorder(Node<?> n)
{
Queue<Node<?>> nodequeue = new LinkedList<Node<?>>();
if (n != null)
nodequeue.add(n);
while (!nodequeue.isEmpty())
{
Node<?> next = nodequeue.remove();
System.out.print(next.data + " ");
if (next.getLeft() != null)
{
if (next.getLeft().getLeft() != null)
nodequeue.add(next.getLeft().getLeft());
if (next.getLeft().getRight() != null)
nodequeue.add(next.getLeft().getRight());
}
if (next.getRight() != null)
{
if (next.getRight().getLeft() != null)
nodequeue.add(next.getRight().getLeft());
if (next.getRight().getRight() != null)
nodequeue.add(next.getRight().getRight());
}
}
}
public static void main(final String[] args)
{
Node<Integer> one = new Node<Integer>(1);
Node<Integer> two = new Node<Integer>(2);
Node<Integer> three = new Node<Integer>(3);
Node<Integer> four = new Node<Integer>(4);
Node<Integer> five = new Node<Integer>(5);
Node<Integer> six = new Node<Integer>(6);
Node<Integer> seven = new Node<Integer>(7);
Node<Integer> eight = new Node<Integer>(8);
Node<Integer> nine = new Node<Integer>(9);
one.setLeft(two);
one.setRight(three);
two.setLeft(four);
two.setRight(five);
three.setLeft(six);
four.setLeft(seven);
six.setLeft(eight);
six.setRight(nine);
System.out.println("\nPre-Order of the Tree");
preorder(one);
System.out.println("\nIn-Order of the Tree");
inorder(one);
System.out.println("\nPost-Order of the Tree");
postorder(one);
System.out.println("\nLevel-Order Odd Levels of the Tree");
levelorder(one);
}
}
Output:
$ javac BinaryTreePrintOddLevels.java $ java BinaryTreePrintOddLevels Pre-Order of the Tree 1 2 4 7 5 3 6 8 9 In-Order of the Tree 7 4 2 5 1 8 6 9 3 Post-Order of the Tree 7 4 5 2 8 9 6 3 1 Level-Order Odd Levels of the Tree 1 4 5 6
Related posts:
Java Program to Describe the Representation of Graph using Adjacency List
Java List UnsupportedOperationException
String Joiner trong Java 8
Hướng dẫn Java Design Pattern – Null Object
Case-Insensitive String Matching in Java
Java Program to Implement Sieve Of Atkin
HttpClient Basic Authentication
Spring Boot - File Handling
Introduction to Spring Boot CLI
Introduction to Eclipse Collections
Using Optional with Jackson
Guide to Java Instrumentation
REST Web service: Upload và Download file với Jersey 2.x
New Features in Java 8
Introduction to Java 8 Streams
Java Program to Implement Suffix Tree
Lấy ngày giờ hiện tại trong Java
Spring JDBC
Java Program to Implement CopyOnWriteArrayList API
Beans and Dependency Injection
The SpringJUnitConfig and SpringJUnitWebConfig Annotations in Spring 5
Generating Random Numbers in a Range in Java
Java Program to Implement Segment Tree
Spring Security Registration – Resend Verification Email
Default Password Encoder in Spring Security 5
Java Program to Implement Miller Rabin Primality Test Algorithm
Java Program to Generate a Random Subset by Coin Flipping
Java Program to Implement CopyOnWriteArraySet API
Java Program to Implement LinkedTransferQueue API
A Guide to Concurrent Queues in Java
Java Program to Implement Stack using Two Queues
Jackson – JsonMappingException (No serializer found for class)