算法分析-插入排序INSERT_SORT与选择排序SELECT_SORT【线性方法】

时间:2022-01-04 20:38:26
 var A = [5, 2, 4, 6, 1, 3];
console.log("排序前-:")
A.forEach(function (element, index, arr) {
console.log(index, "-----------", element);
}); function insertion_sort(A) {
var len = A.length;
for (var i = 1; i < len; i++) {
let key = A[i];
let j = i - 1;
while (j >= 0 && A[j] > key) {
A[j + 1] = A[j];
j--;
}
A[j + 1] = key;
}
} insertion_sort(A);
console.log("排序后-");
A.forEach(function (element, index, arr) {
console.log(index, "-----------", element);
});

上面的代码是算法导论里给的伪代码例子,是一种升序的写法,那降序的怎么写呢:

 function insertion_sort(A) {
var len = A.length;
for (var i = 1; i < len; i++) {
let key = A[i];
let j = i - 1;
while (j >= 0 && A[j] < key) {
A[j + 1] = A[j];
j--;
} A[j + 1] = key;
}
}

在给一个选择排序的算法(升序):

 function SelectSort(A) {
var len = A.length;
for (var i = 0; i < len; i++) {
var min = A[i];
var index = i;
var temp = A[i];
for (var j = i + 1; j < len; j++) {
if (A[j] < min) {
min = A[j];
index = j;
}
}
A[i] = min;
A[index] = temp; } }

线性排序的方法里还有个冒泡,就是两两互换,也是线性的。下一篇讲解分治。