我需要制作一个程序来接受数字输入文件(integer.txt),每行将一个数字排序到一个 vector 中,然后使用选择排序算法对数字进行降序排序并写入它们到输出文件 (sorted.txt)。我很确定我的 selectionSort() 函数有问题导致循环无法获得正确的值,因为在用 cout 测试后我得到了非常不正确的输出。我敢肯定这是初学者的错误。
vector<string> getNumbers()
{
vector<string> numberList;
ifstream inputFile ("integer.txt");
string pushToVector;
while (inputFile >> pushToVector)
{
numberList.push_back(pushToVector);
}
return numberList;
}
vector<string> selectionSort()
{
vector<string> showNumbers = getNumbers();
int vectorMax = showNumbers.size();
int vectorRange = (showNumbers.size() - 1);
int i, j, iMin;
for (j = 0; j < vectorMax; j++)
{
iMin = j;
for( i = j; i < vectorMax; i++)
{
if(showNumbers[i] < showNumbers[iMin])
{
iMin = i;
}
}
if (iMin != j)
{
showNumbers[j] = showNumbers [iMin];
}
}
return showNumbers;
}
void vectorToFile()
{
vector<string> sortedVector = selectionSort();
int vectorSize = sortedVector.size();
ofstream writeTo;
writeTo.open("sorted.txt");
int i = 0;
while (writeTo.is_open())
{
while (i < vectorSize)
{
writeTo << sortedVector[i] << endl;
i += 1;
}
writeTo.close();
}
return;
}
int main()
{
vectorToFile();
}
最佳答案
vectorRange 已定义但未使用。
关于c++ - 选择排序循环中的错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19530908/