Geeksforgeeks

X

DAYS

:

HOUR

:

MINS

:

SEC

Error

Copied to Clipboard

Given two binary trees, the task is to find if both of them are identical or not.

**Example 2:**

**Input:
** 1 1
/ \ / \
2 3 2 3
**Output: **Yes**
Explanation: **There are two trees both
having 3 nodes and 2 edges, both trees
are identical having the root as 1,
left child of 1 is 2 and right child
of 1 is 3.

**Example 2:**

**Input:
** 1 1
/ \ / \
2 3 3 2
**Output: **No**
Explanation: **There are two trees both
having 3 nodes and 2 edges, but both
trees are not identical.

**Your task:**

Since this is a functional problem you don't have to worry about input, you just have to complete the function **isIdentical()** that takes two roots as parameters and returns true or false. The printing is done by the driver code.

**Expected Time Complexity: **O(N).

**Expected Auxiliary Space: **O(Height of the Tree).

**Constraints:**

1 <= Number of nodes <= 10^{5}

1 <=Data of a node <= 10^{5}

We are replacing the old Disqus forum with the new Discussions section given below.

Click here to view old Disqus comments.

Click here to view old Disqus comments.

Login to report an issue on this page.

We strongly recommend solving this problem on your own before viewing its editorial. Do you still want to view the editorial?

YesLoading...

Determine if Two Trees are Identical

...