所以我已经阅读了大约五六篇关于如何重新排列数组的文章,有些是按字母顺序排列的,有些是按数字排列的,我还阅读了这一章。这是我最后想出来的,
void selectionSort (string array[], int size)
{
int startScan, minIndex;
string minValue;
for(startScan = 0; startScan<(size-1); startScan++)
{
minIndex = startScan;
minValue = array[startScan];
string temp;
for(int index = startScan+1; index<size; index++)
if(array[index] <minValue)
{
minValue = array[index];
minIndex = index;
}
}
array[minIndex] = array[startScan];
array[startScan] = minValue;
system("pause");
}
显然,这是行不通的。当我运行它时,它向我抱怨需要打破它。我认为这会起作用,无论是 int 还是任何数字类型。哎呀,如果我将它设置为 char 类型的 ASCII 值,它甚至可能会运行。但实际的分配是一个字符串,我就是想不通。我想过尝试剪掉第一个字母并转换为 char 以按字母顺序排列,但有些字符串的姓氏相同,名字不同,所以这也行不通。
我需要解决什么问题才能让我的排序按字母顺序排列我的数组?
更新阅读评论并重新回顾本书后,更新了我在代码中所做的更改。运行代码时我不再收到错误,但它仍然没有排序!