我正在为我的数据结构课程编写一个程序,我遇到了一个问题,我的选择排序似乎只运行一次。它用于按零件编号组织阵列。
这是它的代码:
    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          
它应该取最大值并将其放在数组的最后,并重复此操作,直到所有内容都在其位置上……但事实并非如此。有没有人知道我在这里做错了什么?谢谢!