Answered You can buy a ready-made answer or pick a professional tutor to order an original one.
i have to solve this
Write a C++ program to implement a menu-driven program for managing a software store using binary search trees. When the program starts, all information about the software packages should be stored in a file named software. The information includes the code, name, version, and price of each software package. Each field will be on a separate line.
When the program starts, it should automatically create a binary search tree with one node corresponding to one software package, and it should include the code of the package. The program should allow the file and the tree to be updated when a new software package arrives to the store and when some packages are sold. Consider the following:
- New packages should be inserted to the tree and at the end of the file.
- Sold packages should be deleted from the file and from the tree.
Test your program using the following example:
- Start with the following content in the file software:
- 12
- Photoshop
- CS5
- 500
- 22
- Office
- 2010
- 150
- 34
- Visual Studio
- 2010
- 600
- Add the following item to the file and tree:
- 15
- Norton Security
- 2014
- 50
- Delete software package with code (2) from the file and the tree.
- @
- 22 orders completed
- ANSWER
-
Tutor has posted answer for $30.00. See answer's preview
*** the **** ** **** ** *********** also # include ***************** ******* **************** include <fstream># ******* <string>using ********* ********** ***** int ***** ****** **** *left; struct **** *right;}*root; class ************ ******* void load_data_from_file(); **** ************************************** void ********************** **** ******** **** ** node **); **** insert(node ***** *); **** del(int); **** *********** *node *); void *********** ***** *** void case_c(node ***** *** **** ************ * ***** binary_tree() * **** = ***** ********************** ****** ******* int ****** **** *********** bst; node ****** ****** nameversionprice; ***** *** { ******************** ******* ************** ******************** ******* "<<endl; *********************************** ******************************** cout<<"Enter your ****** : ** ****************** switch(choice) * case 1: **** = *** ***** ****************** *** details ** the ******** ** ** ******** ******** : * << ***** cout ******** "Enter *** **** * ** cin>>temp->info; **** ******** "Enter *** name * ** ************ getline(cin **** ****** **** ******** ****** *** ******* : "; *** >> ******** cout ******** ****** the price * "; *** ******** ****** if *************** temp) ){ ************************************************* } else * **** << ********* **** *** **** code exists" ******** ***** * break; **** ** ** (root == NULL) * ***************** is ***** nothing ** delete"<<endl; ********* } cout<<"Enter *** ****** ** be ******* * "; *************** bstdel(num); ************************* ****** case ** ******************** ************************** ****************** ***************** ****** **** 4: exit(1); ******** cout<<"Wrong ******************** } ***** **** ******* ** the ********** ********************* item **** ***** **** ******* node *ptr *ptrsave; ** (root == ***** * **** * ***** **** = NULL; ******* * ** ***** ** root->info) { **** = ***** **** * NULL; ******* } ** ***** **** ************** *** = ************** **** *** * *************** ptrsave = ***** ***** **** != NULL) * if ***** == ************* * **** * **** *par * ******** ******* } ptrsave * ptr; ** (item < ptr->info) *** = ************* **** *** * ptr->right; * **** * ***** **** * ************ ********* ******* **** *** ********** binary_tree::load_data_from_file(){ ******** *********************** *** lineNumber * ** ****** ***** **** ****** while( ************* ******* **** ) * * ** (lineNumber * * ** ** * **** * *** ***** ************* = atoi(linec_str()); ************************** * ************* * *************** ***** ******************************* ********** ********** ************* ******* ******** ********************* ******************** outfile ******** **** ******** endl;; ******* << name ******** ****** ******* << version ******** endl; ******* ******** price ******** endl * *************** ************ ********************************* num){ ******** *********************** *** lineNumber = ** *** *********** *** string ***** *** cnt=0; ******** ***** ** ******** ** **** **** ** copied ** * **** **** **** ******* **** ** the path **** ******************** ****** ************* stream1 **** ) ) { ** *********** % * == ** *********** **** { ** * ********** * 4 == ********** ***************** ** **** * *********** =1; cnt=0; } ** ************ ==1) * cnt++; * if **** ==5) * *********** =0; *** = ** * } ** ************ **** { temp << **** ******** endl; * ************* } *************** if( remove( ************* * ** * ******* ****** ******** ***** ** **** puts( ***** ************ ******** ** ************ **************** "softwaretxt"); ***** ************************ *tree **** *newnode){ ** ***** ** ***** * **** * new ***** root->info * ***************** root->left = ***** root->right * ***** //cout<<"Root **** ** Added"<<endl; ****** ** * ** ************** == ***************** * ******************** ******* ** the ****************** ****** 0; * ** ************** **** newnode->info) { if ************** != ***** * ******************** newnode); * **** * ************* * ******** ************************ = ***** ************************* * ***** ******************* ***** ** Left"<<endl; ****** 1; } * **** { if *************** ** ***** * ********************* ********* * else * ************** * ******** ************************* * ***** ************************** * ***** //cout<<"Node ***** ** Right"<<endl; ****** ** } ***** ****** Element from *** ********** ******************** item){ node ******* ********** ** ***** ** ***** * ***************** ******************* return; * ********* *********** *************** if (location ** ***** * cout<<"Item *** ******* in ****************** ******* } ** (location->left ** **** && ****************** ** ***** case_a(parent ********** ** ****************** ** **** && ****************** ** ***** case_b(parent ********** ** ****************** ** **** ********** ****************** ** NULL) ************* location); ** (location->left != **** ********** ****************** ** NULL) ************* ********** free(location);}/** **** A*/void ************************ *par **** **** ** if **** == NULL) * **** * NULL; * **** * ** **** ** ************* ************ * ***** **** ************* = ***** ***** **** B*/void ************************ **** **** ****** node ******* if ************* ** NULL) ***** * ************* else child * ************** ** **** ** ***** * root * ****** * **** * ** **** ** ************* ************ = child; **** ************* * child; ***** **** ******* binary_tree::case_c(node **** **** ****** **** **** *ptrsave **** ******** ******* * loc; *** * ************** ***** (ptr->left ** ***** * ptrsave * **** *** = ************* * *** = **** ****** * ******** ** ************* == **** ********** ************* == ***** case_a(parsuc suc); **** case_b(parsuc ***** if **** == NULL) * root * suc; } else * ** **** ** ************* ************ = **** else par->right = **** * ************ = ************* suc->right * loc->right;} /** ******* **** *************** ************************* **** *** ******* *** i; ** (ptr != ***** * ********************* ********* ***************** ** **** == ***** *********************** ** **** * for ** * 0;i < ********** ************* "; * ************************* ******************** ********* ****