Exercise 5 on Binary Tree Due Date : 6 October Bonus of 2 points if submitted on or before the due date
The Family Ancestry Make a program that will create a binary tree of a family starting from the parents. The program should : Make a program that will create a binary tree of a family starting from the parents. The program should : 1. Create first the root of the binary family tree 2. Add the child to either left or right. (max of 2 children only) 3. Before inserting a surname, search first its parent. Use either inorder/preorder/postorder traversal to search. 4. The program should be able to post a comment for the person, i.e. “dead”, “in USA”, “in the moon”, etc..
Illustration John –dead, Mary Anne, Roger-dead Mike, Mary root
Your program may have the following options 1- Create parent 1- Create parent 2- Search a person 2- Search a person 3- Insert a Child 3- Insert a Child 4- Post a comment 4- Post a comment
Declaration struct node { char *name; char *name; char *remarks; char *remarks; char *partner_name; char *partner_name; char *partner_remarks; char *partner_remarks; node * left, *right; node * left, *right;}
Now let’s write the algorithms Create parent Create parent Search a person Search a person Insert a child Insert a child Post a comment Post a comment
For 1 bonus point..give me a start.. function CreateParent(root) 1. root = new node; 2. root->name = inputname; 3. root->partnername = partner; 4. root->remarks= “”; 5. root->partner_remarks=“”; 6. return root;
Search SearchPerson(isfound,node, inputname) If node !=NULL if node->name = inputname if node->name = inputname isfound = true isfound = true return(node) return(node) else else if not isfound { if not isfound { return(SearchPerson(node->left); return(SearchPerson(node->left); if not isfound() if not isfound() return(SearchPerson(node->right); return(SearchPerson(node->right);
Insert a Child InsertChild(parentname,childname,root) parent = SearchPerson(isfound,root,parentname) If parent <> NULL childnode =CreateChild(childname); childnode =CreateChild(childname); if parent->left <> NULL if parent->left <> NULL parent->left = childnode; parent->left = childnode; else else parent->right = childnode; parent->right = childnode;
Post A Comment PostComment(inputname,comment,root) person= SearchPerson(isfound,root,inputname) If person <> NULL then person-> remarks = comment person-> remarks = comment