This post is completed by 3 users
|
Add to List |
425. Check if the given binary tree is Full or not
Objective: Given a binary tree, write an algorithm to check if the tree is Full or not.
Full binary tree: A binary tree T is full if each node is either a leaf or possesses exactly two child nodes. See the example below
data:image/s3,"s3://crabby-images/9d5ef/9d5ef70876e39d9f842c08066d83dc535ae5b096" alt=""
Approach:
- Do postorder traversal.
- Check if the node is a leaf node (means node does not have either left or right child node), return true.
- Check if the node has only one child (either left or right child node), return false.
- Make a recursive call to the left and right child and do AND before returning the result.
- See the image below for more understanding.
data:image/s3,"s3://crabby-images/9e31b/9e31b418c22843e96a78b85b67573c0f8c7823fe" alt=""
Output:
Given binary is FULL tree: true Given binary is FULL tree: false
Reference: here