Answered step by step
Verified Expert Solution
Link Copied!

Question

1 Approved Answer

Implement the bag type (.cpp file) and add to main.cxx to check all the functions! https://drive.google.com/drive/u/0/folders/1ymO6Q1MU2f_2a1MmsjrgFONivmQu_N70 look at the .h file and see what we

Implement the bag type (.cpp file) and add to main.cxx to check all the functions!

https://drive.google.com/drive/u/0/folders/1ymO6Q1MU2f_2a1MmsjrgFONivmQu_N70

look at the .h file and see what we need to implement

A. Private Variables

value_type *data; size_type used; size_type capacity;

B. Implement Constructors and Destructors

bag(size_type initial_capacity= DEFAULT_CAPACITY) You need to create *data to point to a dynamic array (using the new) of

value_type with initial_capacity. Set used and capacity accordingly bag(const bag& source)

Copy constructor. make sure you do a DEEP COPY meaning you create another dynamic array and set the array of our current bag instance to the array of the source instance. You also have to set used and capacity equal.

~bag(); //destructor Destructor must free the dynamic memory allocated using delete command

C. Insert

void insert(const value_type& entry); //inserts into your bag

Insert the value into your dynamic array. Note that if you are at capacity, you need to reserve more space (i.e. make your bag bigger!).

D. Reserve

void reserve(size_type new_capacity);

Reserve is our first private function We can make reserve a private function because its only called from other member functions (i.e. it shouldnt be called from main). Make a new dynamic array with a greater capacity than your current bag. Then copy over your old bag into your new bag and then DELETE your old bag.

E. Erase_one and Erase

bool erase_one (const value_type& target);//erase 1 of the target value

erase 1 deletes 1 of the target value in the bag (in this case it returns true). Or it returns false if none exist in the bag //if bag a has 1 2 3 4 in it a.erase_one(3)

//bag a now has 1 2 4 in it.

size_type erase(const value_type& target)

erases all the values of target in the bag. //if bag a has 2 2 3 4 in it a.erase(2) //bag a now has 3 4 in it

You should call erase_one from erase

F. Operator+= and Operator=

void operator +=(const bag& addend);

Operator += will do the following //lets say bag a has 1 2 3 and bag b has 4 5 6 a+=b; //now bag a has 1 2 3 4 5 6, you can use insert here

void operator =(const bag& addend);

//lets say bag a has 1 2 3 and bag b has 2 3 4 5 6 a=b //now bag a has 2 3 4 5 6

G. Size, Count, cout<<

size_type size() const {return used;} size_type count (const value_type& target) const; friend std::ostream& operator <<(std::ostream& outs, const bag& source);

Cout and size are implemented for you. count takes in a target and gives you how many of a given type are in your instance //if bag a has 4 5 3 4 cout<

Step by Step Solution

There are 3 Steps involved in it

Step: 1

blur-text-image

Get Instant Access to Expert-Tailored Solutions

See step-by-step solutions with expert insights and AI powered tools for academic success

Step: 2

blur-text-image_2

Step: 3

blur-text-image_3

Ace Your Homework with AI

Get the answers you need in no time with our AI-driven, step-by-step assistance

Get Started

Recommended Textbook for

Oracle Database 19c DBA By Examples Installation And Administration

Authors: Ravinder Gupta

1st Edition

B09FC7TQJ6, 979-8469226970

More Books

Students also viewed these Databases questions

Question

Where do we find a description of a firms accounting policies?

Answered: 1 week ago

Question

The bonds pay interest on February 1 and August AppendixLO1

Answered: 1 week ago

Question

2. Discuss the steps in preparing a manager to go overseas.

Answered: 1 week ago