gpt4 book ai didi

c++ - C++问题中的选择排序

转载 作者:行者123 更新时间:2023-11-28 03:08:12 25 4
gpt4 key购买 nike

我正在为我的数据结构类(class)编写一个程序,我遇到了一个问题,我的选择排序似乎只运行了一次。它用于按零件号组织阵列。

这是它的代码:

    void sorter::selection ()
{
int i, last, large;
int temp;
for (last = maxSize-1; last >= 1; last --) { //maxSize = 20
large = last;
for (i=0; i < last; i++)
if (group[i].partNumber > group[large].partNumber)
large = i;
}
temp = group[large].partNumber;
group[large].partNumber = group[last].partNumber;
group[last].partNumber = temp;
}

这是输出:

Part Number     
278
142
427
255
562
442
980
6
992
54
550
227
2
31
24
540
766
990
101
5

它应该取最大值并将其放在数组的最后,并重复该操作直到所有内容都就位……但事实并非如此。有没有人知道我在这里做错了什么?谢谢!

最佳答案

您的外部 for 循环的右括号位于错误的位置。这是一个很好的例子,说明了为什么适当的缩进如此重要。试试这个版本:

void sorter::selection()
{
int i, last, large;
int temp;
for (last = maxSize-1; last >= 1; last --)
{
large = last;
for (i=0; i < last; i++)
{
if (group[i].partNumber > group[large].partNumber)
large = i;
} // previously your outer loop ended here!
temp = group[large].partNumber;
group[large].partNumber = group[last].partNumber;
group[last].partNumber = temp;
}
}

关于c++ - C++问题中的选择排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19148777/

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