考慮到 l.r[1..i-1] 是按關鍵字有序的有序序列,則可以利用折半查詢實現「 l.r[1…i-1]中查詢 l.r[i] 的插入位置」如此實現的插入排序為折半插入排序。折半插入排序在尋找插入位置時,不是逐個比較而是利用折半查詢的原理尋找插入位置。待排序元素越多,改進效果越明顯。
//此時high = low-1,且high+1即low的位置即為要插入的位置
for(int j = i-1; j >= low; j--)
l[j+1] = l[j];
l[low] = l[0];
} }
public static void main(string args) ; //0號單元未使用
binaryinsertsort(test);
for(int i = 1; i <= test.length-1; i++)
system.out.print(test[i]+" ");
} }
執行結果:
折半插入排序減少了關鍵字的比較次數,但記錄的移動次數不變,其時間複雜度與直接插入排序相同,時間複雜度為o(n^2)。折半插入排序是「穩定的」。
插入排序 折半插入排序
折半插入排序 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...