0

所以我正在尝试使用排序功能(类似于气泡)并将一个对象传递给它。如果该对象更大(按字母顺序),则 switch 然后返回 true 并在它之前切换它。尽管在 if 语句中,我不断收到错误消息,mySort()其中显示“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)

4

5 回答 5

7
  1. arr应该是一个数组,而不是一个引用,像这样PhoneEntry arr[]

  2. 您应该将整个数组传递给排序,而不是单个元素,如下所示:mySort(entry, count);

除此之外,您的代码显示正常。

我应该补充一点,这不是 C++ 的解决方案:在 C++ 中管理数组的首选方法是使用std::vector<T>标准库中的容器。向量的好处是您不需要“侧面”传递它们的大小。

于 2012-02-21T20:33:16.260 回答
2

您可以使用
指针表示法 -mySort(PhoneEntry * arr, int size)
或数组表示法 - mySort(PhoneEntry arr[], int size)

如果您想在调用函数时传递整个数组,只需执行mySort(entry, count).

于 2012-02-21T20:42:55.880 回答
1

arr不是您方法中的数组。

将您的方法签名更改为

void mySort(PhoneEntry *arr, int size)

并调用你的方法

mySort(entry[count], count);

于 2012-02-21T20:33:32.360 回答
1

据我了解,我正在传递一个对象数组,对吗?

不,您没有传递对象数组。您将引用(由&函数头中的 指示)传递给数组中第 -th 位置的PhoneEntry元素。您可能的意思是在 -- 的标题中需要一个指向实例的指针,并且由于数组的名称可以解释为指向该数组的第一个元素的指针,您可以简单地将第一个参数传递给.countentryPhoneEntry* arrmySortPhoneEntryentrymySort

于 2012-02-21T20:33:49.867 回答
0

替换这个:

void mySort(PhoneEntry * arr, int size)

而不是这个:

// Wrong
mySort(entry[count], count);

...执行其中一项(视情况而定):

// Always passes the start of the array, "entry[0]":
 mySort(entry, count);

// Passes a pointer to a particular entry,  onwards:
 mySort(&entry[count], count);
于 2012-02-21T20:34:03.763 回答