gpt4 book ai didi

c++ - 选择排序有一些不合适的元素

转载 作者:行者123 更新时间:2023-11-30 03:14:29 25 4
gpt4 key购买 nike

我正在尝试使用没有指针或地址的选择排序。然而,这种选择排序的输出有时会有一些不合适的元素。

我已经尝试在交换前使用 cout 查看 i 和 minIdx 的索引,并且索引是正确的。但是,它似乎没有将它们交换到正确的位置。

void SortArray (int v[], int size) {

int i, j, minIdx, temp;

for (i = 0; i < size - 1; i++) {
int minIdx = i;
for (j = i + 1; j < size; j++) {
if (v[j] < v[minIdx]) {
minIdx = j;
}
temp = v[i];
v[i] = v[minIdx];
v[minIdx] = temp;
}

PrintArray(v, size);
cout<<" "<<endl;
}

}

这是最后的排序。 64 和 62 是错误的。

0243441586462676978

最佳答案

你做的交换太多了。交换应该在内循环完成后发生,例如

for (j = i + 1; j < size; j++) 
{
if (v[j] < v[minIdx])
{
minIdx = j;
}
}
temp = v[i];
v[i] = v[minIdx];
v[minIdx] = temp;

关于c++ - 选择排序有一些不合适的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57797806/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com