为什么我的选择排序打印位置与以前相同?

问题描述

再次给我。这次,我尝试使用JavaScript进行选择排序。一切顺利,直到我的代码没有输出我想要的特定输出为止。如果您尝试在下面运行我的代码,则数组中倒数第二个索引排序不正确。谁能给我一个简短的解释?

这是代码

var num = [30,1,90,3,2,34];
var bilnum = num.length,i,j,min;
var temp = 0;

for(i = 0; i < bilnum - 1; i++){
    min = i;
    for(j = i + 1; j < bilnum ; j++){
        if(num[j] < num[min]){
        min = j;
        }
        if(min != i){
            temp = num[i];
            num[i] = num[min];
            num[min] = temp;
        }
    }
}  

document.write(num)

解决方法

您需要将下面的代码段从内循环移动到外循环的末端,因为需要在找到最小索引后进行交换。

Cdegrees = [-20,-15,-10,-5,5,10,15,20,25,30,35,40]
print ('    C    F')
for C in Cdegrees:
    F = (9.0/5)*C + 32
    print ('%5d %5.1f' % (C,F))

所以代码看起来像这样

if(min != i){
            temp = num[i];
            num[i] = num[min];
            num[min] = temp;
        }