Binary Tree
Binary Tree is a non-linear data structure. It is made up of nodes. Each node can hold a maximum of two nodes, Left and Right. It is to represent hierarchical information.
A node that has no parent is called Root. A link from parent to a child node is called Edge. A node that has the same level as some nodes are called Sibling. A node that has no children is called Leaf.
data:image/s3,"s3://crabby-images/707d2/707d2082d68c27dd3f10499faa812c3f2583e020" alt="Binary Tree"
Traversal
Visiting every node is called Traversal. There are two order types; Breadth-First and Depth-First.
Breadth-First
Visiting every node at the same level before moving to the next level.
data:image/s3,"s3://crabby-images/5e947/5e947555341aa494f77111c84c9edd371767ecc5" alt="Breadth-First"
Depth-First
Visiting every node with going deep to the leaf before moving to the next node of the same level and can be performed in three ways; Pre-Order, In-Order, and Post-Order.
Pre-Order
The left subtree has processed before the right subtree.
data:image/s3,"s3://crabby-images/049ec/049ec34d874ed9d862391fbbd525e646eeda5429" alt="Pre-Order"
In-Order
Similar to Pre-Order. But, start from the Leaf to the upper level of the node.
data:image/s3,"s3://crabby-images/9a385/9a3856b41c8798a16b64694061150ff0fd8ee550" alt="In-Order"
Post-Order
Similar to In-Order. But, instead of going to the upper level first, it is moving to the node of the same level first.
data:image/s3,"s3://crabby-images/8b12d/8b12d207bb8fdb1235e200d80e41b99eaa5780ed" alt="Post-Order"