Java: Get a new binary tree with same structure and same value of a given binary tree
Java Basic: Exercise-177 with Solution
Clone Binary Tree
Write a Java program to get an updated binary tree with the same structure and value as a given binary tree.
Sample Solution:
Java Code:
// Importing necessary Java utilities
import java.util.*;
// Main class Solution
public class Solution {
// Main method
public static void main(String[] args) {
// Creating TreeNode instances
TreeNode t1 = new TreeNode(1);
TreeNode t2 = new TreeNode(2);
TreeNode t3 = new TreeNode(3);
TreeNode t4 = new TreeNode(4);
TreeNode t5 = new TreeNode(5);
// Creating a tree structure
t1.left = t2;
t1.right = t3;
t2.left = t4;
t2.right = t5;
// Printing the original TreeNode
System.out.println("Original Treenode:");
traverseTree(t1);
// Cloning the TreeNode and printing the clone
System.out.println("\nClone of the said Treenode:");
TreeNode result = cloneTree(t1);
traverseTree(result);
}
// Method to clone a given TreeNode
public static TreeNode cloneTree(TreeNode root) {
// Checking if the root is null
if (root == null) {
return null;
}
// Creating a duplicate TreeNode with the same value as the original root
TreeNode dup = new TreeNode(root.val);
// Recursively cloning left and right subtrees
dup.left = cloneTree(root.left);
dup.right = cloneTree(root.right);
return dup; // Returning the cloned TreeNode
}
// Method to traverse the TreeNode in post-order traversal (Left, Right, Root)
private static void traverseTree(TreeNode root) {
// Checking if the root is not null
if (root != null) {
// Traversing the left subtree
traverseTree(root.left);
// Traversing the right subtree
traverseTree(root.right);
// Printing the value of the current TreeNode
System.out.println(root.val);
}
}
}
// Definition of TreeNode class
class TreeNode {
public int val;
public TreeNode left, right;
// Constructor to initialize TreeNode with a value
public TreeNode(int val) {
this.val = val;
this.left = this.right = null;
}
}
Sample Output:
Original Treenode: 4 5 2 3 1 Clone of the said Treenode: 4 5 2 3 1
Flowchart:
Java Code Editor:
Contribute your code and comments through Disqus.
Previous: Write a Java program to partition an given array of integers into even number first and odd number second.
Next: Write a Java program to find the longest increasing continuous subsequence in a given array of integers.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.
https://www.w3resource.com/java-exercises/basic/java-basic-exercise-177.php
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics