cousins-in-binary-tree

Problem

Cousins in Binary Tree

Problem Description

In a binary tree, the root node is at depth 0, and children of each depth k node are at depth k+1.

Two nodes of a binary tree are cousins if they have the same depth, but have different parents.

We are given the root of a binary tree with unique values, and the values x and y of two different nodes in the tree.

Return true if and only if the nodes corresponding to the values x and y are cousins.


Example 1:

    1
   / \
  2   3
 /   
4   

Input: root = [1,2,3,4], x = 4, y = 3
Output: false

Example 2:

       1
      / \
     2   3
      \   \
       4   5

Input: root = [1,2,3,null,4,null,5], x = 5, y = 4
Output: true

Example 3:

          1
         / \
        2   3
         \   
          4   


Input: root = [1,2,3,null,4], x = 2, y = 3
Output: false


Note:

The number of nodes in the tree will be between 2 and 100.
Each node has a unique integer value from 1 to 100.

Solution

BFS -- level by level check whether current level encounter both x and y node, is yes, then compare their parents nodes.

  • construct Node to store node x parent(int parent) and whether encountered(boolean isCurr)

  • use queue to store all treenodes in the same level. ie. example 1, level 0 {1} level 1 {2, 3}, level 2 {4}

  • for each level, we check whether next level node is x node, if yes, store in Node xn{curr.val, true}.

  • after one level traverse, check whether found x and y, if yes, compare parents

    • if x and y parents are the same, continue.

    • if x and y parents are not the same, then return true, already found

    • if only found x or y, then return false.

  • after traverse all nodes, then return fase.

For example

Cousins in Binary Tree

Complexity Analysis

Time Complexity: O(N)

Space Complexity: O(N)

  • N - the number of treenodes

Code

Last updated

Was this helpful?