为什么我的选择排序打印在与以前相同的位置?
Why did my Selection Sort print in the same position as before?
又是我。这次我尝试使用 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)
您需要将下面的代码片段从内循环移动到外循环的末尾,因为您需要在找到最小索引后进行交换。
if(min != i){
temp = num[i];
num[i] = num[min];
num[min] = temp;
}
所以代码看起来像这样
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;
}
}
console.log(num);
又是我。这次我尝试使用 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)
您需要将下面的代码片段从内循环移动到外循环的末尾,因为您需要在找到最小索引后进行交换。
if(min != i){
temp = num[i];
num[i] = num[min];
num[min] = temp;
}
所以代码看起来像这样
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;
}
}
console.log(num);