Code360 powered by Coding Ninjas X Naukri.com. Code360 powered by Coding
Ninjas X Naukri.com

Last Updated: 11 Oct, 2020

Easy

```
The first line contains an Integer 't' which denotes the number of test cases or queries to be run. Then the test cases follow.
The first line of input contains the elements of the tree in the level order form separated by a single space.
If any node does not have left or right child, take -1 in its place. Refer to the example below.
Example:
Elements are in the level order form. The input consists of values of nodes separated by a single space in a single line. In case a node is null, we take -1 on its place.
For example, the input for the tree depicted in the below image would be :
```

```
1
2 3
4 -1 5 6
-1 7 -1 -1 -1 -1
-1 -1
Explanation :
Level 1 :
The root node of the tree is 1
Level 2 :
Left child of 1 = 2
Right child of 1 = 3
Level 3 :
Left child of 2 = 4
Right child of 2 = null (-1)
Left child of 3 = 5
Right child of 3 = 6
Level 4 :
Left child of 4 = null (-1)
Right child of 4 = 7
Left child of 5 = null (-1)
Right child of 5 = null (-1)
Left child of 6 = null (-1)
Right child of 6 = null (-1)
Level 5 :
Left child of 7 = null (-1)
Right child of 7 = null (-1)
The first not-null node (of the previous level) is treated as the parent of the first two nodes of the current level. The second not-null node (of the previous level) is treated as the parent node for the next two nodes of the current level and so on.
The input ends when all nodes at the last level are null (-1).
```

```
The above format was just to provide clarity on how the input is formed for a given tree.
The sequence will be put together in a single line separated by a single space. Hence, for the above-depicted tree, the input will be given as:
1 2 3 4 -1 5 6 -1 7 -1 -1 -1 -1 -1 -1
```

```
For each test case, print the inorder traversal of the tree where each node is replaced by the depth of the current node.
Output for every test case will be denoted in a separate line.
```

```
You do not need to print anything, it has already been taken care of. Just implement the given function.
```

```
1 <= T <= 100
1 <= N <= 1000
-10^9 <= data <= 10^9
Time limit: 1 sec
```

Traverse tree starting from the root. While traversing the tree, pass the depth of the node as a parameter. We can track depth by passing it as 0 for root and increment depth for the children by 1.

fHelp(Node root, level=0)

- If root is NULL
- Return

- root -> data = level
- fHelp(root -> left, level + 1)
- fHelp(root -> right, level + 1)

f(Node root)

fHelp(root, 0)

Do level order traversal of the tree using queue and in the queue at a time store all the elements in the current level of the tree, and store the parent node of the level by calling the front element of the queue.

Then push the left and right nodes of the current node in the queue. Also, update the data of left subtree to its parent node +1, also do the same for the right subtree.

Similar problems

Ninja and Tree

Ninja

Posted: 5 Feb, 2022

Kth Largest Element in BST

Moderate

Posted: 12 Mar, 2022

Height of Binary Tree

Easy

Posted: 22 Apr, 2022

Height of Binary Tree

Easy

Posted: 22 Apr, 2022

Height of Binary Tree

Easy

Posted: 22 Apr, 2022

Min Heap

Moderate

Posted: 5 May, 2022

Min Heap

Moderate

Posted: 5 May, 2022

Locked Binary Tree

Easy

Posted: 12 May, 2022