直接插入排序其插入位置是在部分排序陣列的後面開始判斷找到插入位置,而折半插入排序是利用二分查詢的方式找到插入位置
package alg.sort;
public
class bininsertsort
a[id] = x;}}
// 二分查詢找到對應的插入位置
public
intbinaryid(int a,int left,int right,int x)
return left;
}public
static
void
main(string args);
printarray.printarray(a);
bininsertsort bininsertsort = new bininsertsort();
bininsertsort.sort(a);
printarray.printarray(a);
}}
(1)時間複雜度
對於折半查詢時間複雜度o(
log2
n)移動元素時間複雜度o(
n)最好情況:不需要移動元素,但是查詢的時間還是o(
log2
n),時間複雜度o(
nlog
2n)
最壞情況:需要移動元素,時間複雜度o(
n2)
平均時間複雜度o(
n2)
(2)空間複雜度
只用到常量的變數,空間複雜度o(
1)
插入排序 折半插入排序
折半插入排序 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...
插入排序 折半插入排序
package sort 折半插入排序 當序列是連續儲存時,對直接插入排序進行的改進 插入位置可以更快速找到 直接插入排序a 0 用作哨兵減少條件判斷,折半插入排序不需要哨兵a 0 位置存放實際元素 public class insertsort 統一後移,空出插入位置 for j i 1 j hi...