插入排序:將陣列中的資料分為兩個區間,已排序區間和未排序區間。初始已排序區間只有乙個元素,就是陣列的第乙個元素。插入演算法的核心思想是取未排序區間中的元素,在已排序中找到合適的插入位置將其插入,並保證已排序空間資料一直有序。重複這個過程,直到未排序區間中元素為空。
插入排序是原地、穩定的排序演算法。
原地:執行並不需要額外的儲存空間,空間複雜度為o(1)。
穩定:對於值相同的元素,選擇將後面出現的元素,插入到前面出現元素的後面,保持原有的前後順序不變。
時間複雜度:最好是從尾到頭遍歷已經有序的資料為o(n),最壞是陣列是倒序的為o(n*2),平均是每次插入操作都相當於在陣列中插入乙個資料,迴圈執行n次插入操作為o(n*2)。
測試作用域:
public class insertion
system.out.println(i);
}}
插入排序:
public class insertion ;
sort(arr);
for (int a: arr)
}public static void sort(int arr)
} for (int i = 1; i < arr.length; i++) else
}//j=-1
// 插入資料
arr[j+1] = value;//j+1=0
} }
}
插入排序 折半插入排序
折半插入排序 binary insertion sort 直接插入排序採用順序查詢法查詢當前記錄在已排好序的序列中插入位置,這個 查詢 操作可利用 折半查詢 來實 現,由此進行的插入排序稱之為折半插入排序 binary insertion sort 演算法思想 1 將待排序的記錄存放在陣列r 1.n...
插入排序 折半插入排序
折半插入排序是基於直接插入排序的優化。直接插入排序 將第i個元素插入時,通過折半查詢的方式,來查詢第i個元素合適的位置。當0 i 1 位置上的元素都已經排序ok,現需要插入第i個元素,設其值為temp 令low 0,high i,mid high low 2。那麼temp可能插入的位置是 low h...
插入排序 希爾插入排序
本文借鑑於lsgo實驗室創始人馬老師 演算法 希爾插入排序 delta len nums 2 while delta 0 shell delta,nums delta delta 2return nums defshell delta,key for i in range delta,len key...