Here is the code provided. I'm confused on the premise of these questions. Main(). #include #include "flexArray.h" using namespace std; int main() { flexArray f; f.SetLength(5); f.SetElement("Hello", 0); f.SetElement("World", 1); f.SetElement("THIS SHOULD FAIL", 6); for (int i = 0; i < f.GetLength(); i++) { cout << "Element " << i << " = " << f.GetElement(i) << endl; } f.SetLength(10); f.SetElement("THIS SHOULD NOT FAIL", 6); for (int i = 0; i < f.GetLength(); i++) { cout << "Element " << i << " = " << f.GetElement(i) << endl; } return 0; header file. #ifndef __FLEXARRAY_H__ #define __FLEXARRAY_H__ #include // This is an array of strings class flexArray { public: flexArray(); // Default constructor flexArray(unsigned int arrayLen); // Constructor with a length param ~flexArray(); // Destructor: cleans up dynamically-allocated memory unsigned int GetLength(); void SetLength(unsigned int updatedLength); std::string GetElement(unsigned int position); void SetElement(std::string update, unsigned int position); private: unsigned int _length; // this is the current length of the array std::string* _array; // this is where we put the actual values }; #endif /* __FLEXARRAY_H__ */ flexArray.cpp #include "flexArray.h" flexArray::flexArray() { // Default constructor // _length and _array _length = 100; // Setting the length to the default 100 _array = new std::string[_length]; // Dynamically allocate the array } flexArray::flexArray(unsigned int arrayLen) { // Constructor with a length param // _length and _array _length = arrayLen; // Setting the length to the parameter _array = new std::string[_length]; // Dynamically allocate the array } flexArray::~flexArray() { // Destructor: cleans up dynamically-allocated memory delete [] _array; // Deallocating the array before closing } unsigned int flexArray::GetLength() { return _length; } void flexArray::SetLength(unsigned int updatedLength) { // Step 1: Allocate space // Step 2: Copy over elements // Step 3: Delete old array // Step 4: Update with new array } std::string flexArray::GetElement(unsigned int position) { } void flexArray::SetElement(std::string update, unsigned int position) { }
Here is the code provided. I'm confused on the premise of these questions.
Main().
#include <iostream>
#include "flexArray.h"
using namespace std;
int main() {
flexArray f;
f.SetLength(5);
f.SetElement("Hello", 0);
f.SetElement("World", 1);
f.SetElement("THIS SHOULD FAIL", 6);
for (int i = 0; i < f.GetLength(); i++) {
cout << "Element " << i << " = " << f.GetElement(i) << endl;
}
f.SetLength(10);
f.SetElement("THIS SHOULD NOT FAIL", 6);
for (int i = 0; i < f.GetLength(); i++) {
cout << "Element " << i << " = " << f.GetElement(i) << endl;
}
return 0;
header file.
#ifndef __FLEXARRAY_H__
#define __FLEXARRAY_H__
#include <string>
// This is an array of strings
class flexArray {
public:
flexArray(); // Default constructor
flexArray(unsigned int arrayLen); // Constructor with a length param
~flexArray(); // Destructor: cleans up dynamically-allocated memory
unsigned int GetLength();
void SetLength(unsigned int updatedLength);
std::string GetElement(unsigned int position);
void SetElement(std::string update, unsigned int position);
private:
unsigned int _length; // this is the current length of the array
std::string* _array; // this is where we put the actual values
};
#endif /* __FLEXARRAY_H__ */
flexArray.cpp
#include "flexArray.h"
flexArray::flexArray() { // Default constructor
// _length and _array
_length = 100; // Setting the length to the default 100
_array = new std::string[_length]; // Dynamically allocate the array
}
flexArray::flexArray(unsigned int arrayLen) { // Constructor with a length param
// _length and _array
_length = arrayLen; // Setting the length to the parameter
_array = new std::string[_length]; // Dynamically allocate the array
}
flexArray::~flexArray() { // Destructor: cleans up dynamically-allocated memory
delete [] _array; // Deallocating the array before closing
}
unsigned int flexArray::GetLength() {
return _length;
}
void flexArray::SetLength(unsigned int updatedLength) {
// Step 1: Allocate space
// Step 2: Copy over elements
// Step 3: Delete old array
// Step 4: Update with new array
}
std::string flexArray::GetElement(unsigned int position) {
}
void flexArray::SetElement(std::string update, unsigned int position) {
}
data:image/s3,"s3://crabby-images/5340e/5340e8bfa4b580b466e283aa15fe3df5040d4a9c" alt="1. Build the setLength function. If the new length is shorter than the current array,
copy only enough items from the previous array to fill the new array. If it's longer,
copy all of the old items into the new array and initialize the remaining elements
to the empty string
11 T
2. Build the setElement function. This is a fairly simple mutator that changes the
string at the specified location to the new value.
3. Build the getElement function. This is a fairly simple accessor that returns the
string at the specified location."
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 6 steps with 4 images
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"