Поэтому я пытаюсь использовать функцию сортировки (похожую на пузырь) и передать в нее объект. Если этот объект больше (в алфавитном порядке), то переключитесь, верните истину и переключите его с предыдущим. Я продолжаю получать сообщение об ошибке внутри оператора if внутри mySort()
, который говорит: «нет совпадения для operator [] в arr [j]», но, насколько я понимаю, я передаю массив объектов, верно? Почему это происходит и как я могу это решить?
Вот драйвер
#include <iostream>
#include <fstream>
#include <string>
#include "phoneEntry.h"
using namespace std;
void mySort(PhoneEntry &arr, int size)
{
bool inOrder = false;
string temp;
for (int i = size - 1; i > 0 && !inOrder; i--)
{
inOrder = true;
for (int j = 0; j < i; j++)
{
if(arr.alphaGreater(arr[j]))
{
inOrder = false;
temp = arr[j];
arr[j] = arr[j + 1];
arr[j + 1] = temp;
}
}
}
};
int main()
{
const int MAXNUM = 500;
PhoneEntry entry[MAXNUM];
ifstream filezilla;
filezilla.open("phone.txt");
int count = 0;
if(filezilla)
{
while(count < MAXNUM && entry[count].readEntry(filezilla))
{
count++;
mySort(entry[count], count);
}
for(int i = 0; i < count; i++)
{
entry[i].writeEntry(cout) << endl;
}
}
else
{
cout << "404" << endl;
}
return 0;
}
Заголовок телефонного номера
Заголовок номера телефона
Сортировка текста (http://pastebin.com/HE8Rsmbg)