问题描述
再次给我。这次,我尝试使用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;
}