Geeksforgeeks

Error

×

Leaderboard

Showing:

Handle | Score |
---|---|

@Ibrahim Nash | 5725 |

@blackshadows | 5685 |

@akhayrutdinov | 5111 |

@mb1973 | 4989 |

@Quandray | 4908 |

@saiujwal13083 | 4156 |

@sanjay05 | 3762 |

@marius_valentin_dragoi | 3511 |

@sushant_a | 3453 |

@KshamaGupta | 3318 |

@the_coder95 | 3302 |

Complete Leaderboard | |

Handle | Score |

@shashi1iitk | 398 |

@Suniti Jain | 114 |

@ankish2000nayak | 104 |

@gopalsethlnct | 94 |

@senthil1185 | 90 |

@esmadhan | 90 |

@gyanadipta07 | 89 |

@satwikdash2000 | 85 |

@varunmishra3040 | 83 |

@gamec1634 | 82 |

@pj_1721 | 80 |

Complete Leaderboard |

Given a Binary Tree, the task is to complete the function **dupSub** which takes the root of the tree as the only argument and returns true if the Binary tree contains a duplicate sub-tree of size two or more.

```
Input : Binary Tree
A
/ \
B C
/ \ \
D E B
/ \
D E
Output : Yes
```

**Note:** Two same leaf nodes are not considered as subtree as size of a leaf node is one.

**Input:**

The first line of input contains an integer T denoting the no of test cases. Then T test cases follow. Each test case contains a string s representing the binary tree.

For example the **string :** (a(b()())(c()()) represents the below binary tree

a

/ \

b c

**Output:**

For each test case output will be 1 if the binary tree contains duplicate sub-tree of size two or more else 0.

**Constraints:**

1<=T<=50

1<=length of string<=100

**Example(To be used only for expected output) :
Input:**

2

(a(b(d()())(e()()))(c()(b(d()())(e()()))))

(a(b()())(c()()))

1

0

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?

Yes
Duplicate subtree in Binary Tree

...

Please choose 'ReadOnlyMode' if you needn't to 'Edit' the problem e.g. viewing OJ's solution, TestCase Files (TCFs), TimeLimit etc.