Write a program in C++ to create a Binary Search tree (BST) of string data. The program will perform these operations: Insert name(s), Traverse Preorder, Search name, Delete name, Leaf Count, sibling of a person and Quit.
(please answer the question in c++ i need the nodes to be able to accept strings like "KIM" used in the example)
Option 4: Deletes a name from the BST.
It will prompt: Enter name you want to delete: TOM
If the name is found then delete the name from the BST and displays the message –“___ is deleted.” If the name is not in the BST, then it will display – “____ is not found in the BST”
TOM is deleted
Option 5: Counts the number of leaves in the BST and displays –
“There are ____ number of leaves in the BST.”
Option 6: Enter a name and it will display the sibling of that person.
It will prompt: Enter the name you want to find the sibling of:
The sibling of ____ is _____
If the person has no sibling, then it displays:
____ has no sibling.
Ex: Enter the item: PAM
The sibling of PAM is DON.
Option 7: Quit the
data:image/s3,"s3://crabby-images/38dfb/38dfb789c876c7371f958cab29a7d00bd93bc38c" alt="Write a program in C++ to create a Binary Search tree (BST) of string data. The program will
perform these operations: Insert name(s), Traverse Preorder, Search name, Delete name, Leaf
Count, sibling of a person and Quit.
Use this header file:
class BT
{
private:
public:
};
struct node
{
string data;
node* left;
node* right;
node* root;
BT();
bool isEmpty() const { return root == NULL; }
void insert(string);
void print preorder();
void preorderTrav(node*);
void searchBST(string);
void deleteNode(string);
int count();
int leafCount (node*);
void nodeSibling (string);
Use the following menu in your program. Must place your name in the menu heading.
1.
2.
3.
4.
5.
6.
7.
//Constructor
//Check for empty
//Insert item in BST
//Preorder traversing driver
//Preorder traversing
//Searches BST for a specific node
//Delete item in BST
//Count driver
//Counts number of leaves in BST
//Finds sibling of a node
Insert name(s)
Traverse Preorder
Search name
Delete name
Leaf Count
Sibling of a person
Quit
Enter your choice:
Use the following names in the given order to form the BST tree:
KIM PAM DON TOM RON BEN AMY"
data:image/s3,"s3://crabby-images/458c1/458c156cce567e9ecd0d520ee9eec50c8fd96542" alt="Option 1:
Option 2:
Option 3:
Inserts name(s) in a BST.
Enter Your Choice <1-7> 1
Enter number of items to insert: 4
Enter node: KIM
Inserted.
Enter node: PAM
Inserted.
Enter node: DON
Inserted.
Enter node: TOM
Inserted.
Traverse the tree in Preorder and display the node info and its left child info and
right child info. If a node does not have a child then display NIL.
Enter Your Choice <1-7>2
Sample output:
Node Info
KIM
DON
PAM
TOM
Traversing Preorder
Left Child Info Right Child Info
DON
NIL
NIL
NIL
PAM
NIL
Search for the name in the BST.
It will prompt: Enter name you want to search for: KIM
KIM
ΤΟΜ
NIL
If the name is found, then display the name and the left child information and right
child information. If the item is not found, then it will display – “ is not found
in the BST"
Node Info Left Child Info Right Child Info
DON
PAM"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"