js插入排序


插入排序

  • 平均時間復雜度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;
}
相比較上一個版本,少了一些中間比較時進行的賦值,只取最終的位置進行賦值
 


 

 

 

 

 

 

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM