插入排序
- 平均時間復雜度O(n*n)
- 最差情況O(n*n)
- 最好情況O(n)
- 空間復雜度O(1)
- 穩定性:穩定
function insertSort (arr) {
var len = arr.length;
var temp;
for (var i = 1;i < len;i++){
for(var j = i;j > 0 && arr[j] < arr[j-1];j--){
// 當前值和之前的每個值進行比較,發現有比當前值小的值就進行交換
temp = arr[j];
arr[j] = arr[j-1];
arr[j-1] = temp;
}
}
return arr
}
插入排序的排序效率要比選擇排序的高,當排序有一定順序的數組時,效率會非常高
function insertSort(arr) {
var len = arr.length;
var temp;
for (var i = 1;i < len;i++){
temp = arr[i];
for (var j = i;j > 0 && temp < arr[j-1];j--){
// 當前值和之前的每個值進行比較,發現有比當前值小的值就進行重新賦值
arr[j] = arr[j-1];
arr[j-1] = temp;
}
}
return arr;
}
重新賦值比數值交換效率更高一些
最終升級版
function insertSort(arr) {
var len = arr.length;
var temp;
for (var i = 1;i < len;i++){
temp = arr[i]
for (var j = i;j > 0 && temp < arr[j-1];j--){
// 當前值和之前的每個值進行比較,發現有比當前值小的值就進行重新賦值
arr[j] = arr[j-1];
}
arr[j] = temp;
}
return arr;
}
相比較上一個版本,少了一些中間比較時進行的賦值,只取最終的位置進行賦值