Объединить два строковых массива без использования STL или векторов в переполнении стека

Я учу себя C ++, следовательно, ужасное название и очень простой вопрос. Я пытаюсь объединить два массива в C ++. Массив имеет тип строки. Их конструктор позволяет им иметь емкость по умолчанию 12.
В общем, я пытаюсь объединить массивы, чтобы у меня был массив, способный содержать 24 элемента. Я не хочу использовать векторы, и я не хочу использовать STL. В массивах есть несколько предметов, но они не полностью заполняют свои возможности. Ниже вы найдете код.

Вот мое определение класса ArrayBag.h:

#ifndef _ARRAY_BAG
#define _ARRAY_BAG
#include "BagInterface.h"#include <vector>template<class ItemType>
class ArrayBag : public BagInterface<ItemType>
{
private:
static const int DEFAULT_CAPACITY = 24; // the bag size a bit bigger to allow
// adding bags.
ItemType items[DEFAULT_CAPACITY];      // Array of bag items
int itemCount;                         // Current count of bag items
int maxItems;                          // Max capacity of the bag

// Returns either the index of the element in the array items that
// contains the given target or -1, if the array does not contain
// the target.
int getIndexOf(const ItemType& target) const;

public:
ArrayBag();
int getCurrentSize() const;
bool isEmpty() const;
bool add(const ItemType& newEntry);
void clear();
bool remove(const ItemType& anEntry);
bool contains(const ItemType& target) const;
int getFrequencyOf(const ItemType& anEntry) const;
std::vector<ItemType> toVector() const;
}; // end ArrayBag

#endif

И вот моя фактическая реализация класса.

#include "ArrayBag.h"#include <cstddef>

template<class ItemType>
ArrayBag<ItemType>::ArrayBag(): itemCount(0), maxItems(DEFAULT_CAPACITY)
{
}  // end default constructor

template<class ItemType>
int ArrayBag<ItemType>::getCurrentSize() const
{
return itemCount;
}  // end getCurrentSize

template<class ItemType>
bool ArrayBag<ItemType>::isEmpty() const
{
return itemCount == 0;
}  // end isEmpty

template<class ItemType>
bool ArrayBag<ItemType>::add(const ItemType& newEntry)
{
bool hasRoomToAdd = (itemCount < maxItems);
if (hasRoomToAdd)
{
items[itemCount] = newEntry;
itemCount++;
}  // end if

return hasRoomToAdd;
}  // end add

template<class ItemType>
void ArrayBag<ItemType>::clear()
{
itemCount = 0;
}  // end clear

template<class ItemType>
bool ArrayBag<ItemType>::remove(const ItemType& anEntry)
{
int locatedIndex = getIndexOf(anEntry);
bool canRemoveItem = !isEmpty() && (locatedIndex > -1);
if (canRemoveItem)
{
itemCount--;
items[locatedIndex]=items[itemCount];
}//end if
return canRemoveItem;
} //end remove

template<class ItemType>
bool ArrayBag<ItemType>::contains(const ItemType& anEntry) const
{
bool found = false;
int curIndex = 0; //current array index
while(!found && (curIndex < itemCount))
{
if(anEntry == items[curIndex])
{
found = true;
} //end if

curIndex++; //increment to the next entry
} //end while
return found;
}

template<class ItemType>
int ArrayBag<ItemType>::getFrequencyOf(const ItemType& anEntry) const
{
int frequency = 0;
int curIndex = 0; //current index array
while(curIndex < itemCount)
{
if (items[curIndex] == anEntry)
{
frequency++;
} //end if

curIndex++; //incremenet to next entry
} //end while
return frequency;
} //end getFrequencyOftemplate<class ItemType>
vector<ItemType> ArrayBag<ItemType>::toVector() const
{
vector<ItemType> bagContents;
for (int i = 0; i < itemCount; i++)
bagContents.push_back(items[i]);

return bagContents;
}  // end toVector

ArrayBag<string> merge(const ArrayBag<string>& oneBag,
const ArrayBag<string>& anotherBag)
{
int sizeOnebag, sizeAnotherbag, newBagsize;
sizeOnebag = oneBag.getCurrentSize();
sizeAnotherbag = anotherBag.getCurrentSize();
newBagsize = sizeAnotherbag + sizeOnebag;

Выше я взял размер двух сумок и создал новый тип int, который содержит размер двух исходных массивов. Но оттуда я не уверен, что делать. Я попробовал ниже. Но каждый раз получайте предупреждение компилятора.

 ArrayBag<string> finalBag;

int itemCount = finalBag.getCurrentSize();

if (itemCount > newBagsize){
newBagsize++;
itemCount = finalBag.getCurrentSize();
finalBag[itemCount];
}

Ниже находится BagInterface.h

#ifndef _BAG_INTERFACE
#define _BAG_INTERFACE

#include <vector>
using namespace std;

template<class ItemType>
class BagInterface
{
public:
/** Gets the current number of entries in this bag.
@return The integer number of entries currently in the bag. */
virtual int getCurrentSize() const = 0;

/** Sees whether this bag is empty.
@return True if the bag is empty, or false if not. */
virtual bool isEmpty() const = 0;

/** Adds a new entry to this bag.
@post  If successful, newEntry is stored in the bag and
the count of items in the bag has increased by 1.
@param newEntry  The object to be added as a new entry.
@return  True if addition was successful, or false if not. */
virtual bool add(const ItemType& newEntry) = 0;

/** Removes one occurrence of a given entry from this bag,
if possible.
@post  If successful, anEntry has been removed from the bag
and the count of items in the bag has decreased by 1.
@param anEntry  The entry to be removed.
@return  True if removal was successful, or false if not. */
// virtual bool remove(const ItemType& anEntry) = 0;

/** Removes all entries from this bag.
@post  Bag contains no items, and the count of items is 0. */
virtual void clear() = 0;

// I commented this out because I did not implement it.
/** Counts the number of times a given entry appears in bag.
@param anEntry  The entry to be counted.
@return  The number of times anEntry appears in the bag. */

virtual int getFrequencyOf(const ItemType& anEntry) const = 0;

// I commented this out because I did not implement it.

/** Tests whether this bag contains a given entry.
@param anEntry  The entry to locate.
@return  True if bag contains anEntry, or false otherwise. */virtual bool contains(const ItemType& anEntry) const = 0;

/** Empties and then fills a given vector with all entries that
are in this bag.
@return  A vector containing all the entries in the bag. */
virtual vector<ItemType> toVector() const = 0;

virtual bool remove(const ItemType& anEntry) = 0;
}; // end BagInterface
#endif

И вот мой основной файл.

    #include <iostream>
#include <string>
#include "ArrayBag.h"
using namespace std;

void displayBag(ArrayBag<string>& bag)
{
cout << "The bag contains " << bag.getCurrentSize()
<< " items:" << endl;
vector<string> bagItems = bag.toVector();
int numberOfEntries = (int)bagItems.size();
for (int i = 0; i < numberOfEntries; i++)
{
cout << bagItems[i] << " ";
}  // end for
cout << endl << endl;
}  // end displayBag

void displayBag(ArrayBag<int>& bag)
{
cout << "The bag contains " << bag.getCurrentSize()
<< " items:" << endl;
vector<int> bagItems = bag.toVector();
int numberOfEntries = (int)bagItems.size();
for (int i = 0; i < numberOfEntries; i++)
{
cout << bagItems[i] << " ";
}  // end for
cout << endl << endl;
}  // end displayBag

int sumOfBag(ArrayBag<int>& aBag)
{
int sum=0;
vector<int> aBagvector = aBag.toVector();
int numberOfEntries = (int) aBagvector.size();
for (int i = 0; i < numberOfEntries; i++)
{
sum += aBagvector[i];
}
//cout << "The sum of the bag is " << sum << endl;
return sum;
}

void bagTester(ArrayBag<string>& bag)
{
cout << "isEmpty: returns " << bag.isEmpty()
<< "; should be 1 (true)" << endl;
displayBag(bag);

string items[] = {"one", "two", "three", "four", "five", "one"};
cout << "Add 6 items to the bag: " << endl;
for (int i = 0; i < 6; i++)
{
bag.add(items[i]);
}  // end for

displayBag(bag);

cout << "isEmpty: returns " << bag.isEmpty()
<< "; should be 0 (false)" << endl;

cout << "getCurrentSize: returns " << bag.getCurrentSize()
<< "; should be 6" << endl;

cout << "Try to add another entry: add(\"extra\") returns "<< bag.add("extra") << endl;
displayBag(bag);
} // end bagTesterint main()
{
ArrayBag<string> bag;
cout << "Testing the Array-Based Bag:" << endl;
cout << "The initial bag is empty." << endl;
bagTester(bag);
ArrayBag<string> bag_of_strings1;
string items[] = {"tom","dick","harry"};
for (int i=0; i<3; i++) {bag_of_strings1.add(items[i]);}
displayBag(bag_of_strings1);
ArrayBag<string> bag_of_strings2;
string new_items[] = {"now","is","the","time","for","all"};
for(int i=0; i<6; i++){
bag_of_strings2.add(new_items[i]);
}
displayBag(bag_of_strings2);
//ArrayBag<string> newbag=merge(bag_of_strings1,bag_of_strings2);

//displayBag(newbag);

ArrayBag<int> bag_of_ints;
int array_of_ints[]={6,7,85,9,12,15};
for (int i=0;i<6;i++){
bag_of_ints.add(array_of_ints[i]);
}
displayBag(bag_of_ints);
cout<<sumOfBag(bag_of_ints)<<endl;

return 0;
} // end main

3

Решение

Вы можете объявить merge как друг:

public:
friend ArrayBag<string> merge(ArrayBag<string> a, ArrayBag<string> b);
ArrayBag();
int getCurrentSize() const;
bool isEmpty() const;
...

Затем определите слияние как:

ArrayBag<string> merge(ArrayList<string> a, ArrayList<string> b) {
int newsz = a.getCurrentSize() + b.getCurrentSize();
if (newsz > a.DEFAULT_CAPACITY)
// do something here
abort();
ArrayBag<string> result;
for (int c=0; c<a.getCurrentSize(); ++c)
result.add(a.items[c]);
for (int c=0; c<b.getCurrentSize(); ++c)
result.add(b.items[c]);
return result;
}

Конечно, более чистый способ — добавить оператор индекса:

T operator[](size_t x) const { return items[x]; }

Тогда вам не нужно merge быть другом и может заменить a.items[c] а также b.items[c] просто a[c] а также b[c],

2

Другие решения

Вы не показали свой код для ArrayBag, но если вы хотите объединить два массива в стиле C, вам придется создать новый массив из 24 элементов и вручную скопировать (или переместить, если используется C ++ 11 или C ++ 14) элементы, а затем удалить старый массивы.

Кстати, если вы используете std :: string, вы уже используете STL.

0

По вопросам рекламы ammmcru@yandex.ru
Adblock
detector