二分插入排序

2021-06-26 12:49:44 字數 550 閱讀 6958

基本思想:

1.取arr[1]為關鍵字key,將key插入前面已拍好的序列中。

2.取arr[2]為關鍵字key,將key插入前面已拍好的序列中。

。。。3.取arr[n-1]為關鍵字key,將key插入前面已拍好的序列中。

#include #include #define n	10

void binsertsort(int *a, int num);

int main()

; for (int i = 0; i < n; i ++)

printf("\n");

binsertsort(a, n);

for (int i = 0; i < n; i ++)

system("pause");

return 0;

}void binsertsort(int *a, int num)

else

}for (j = i-1; j >= high+1; j --)

a[j+1] = key;

}}

二分插入排序

include 二分插入法排序 二分排序的時間複雜度是o n logn 空間複雜度o 1 是穩定排序 void binary insert sort int a,int len else 如果當前元素比中間元素大,當前元素要插入到中間元素的右側 for j i 1 j high j 元素後移 a h...

二分插入排序

一 折半插入排序 二分插入排序 二 演算法原理 演算法的基本過程 1 計算 0 i 1 的中間點,用 i 索引處的元素與中間值進行比較,如果 i 索引處的元素大,說明要插入的這個元素應該在中間值和剛加入i索引之間,反之,就是在剛開始的位置 到中間值的位置,這樣很簡單的完成了折半 2 在相應的半個範圍...

二分插入排序

二分 折半 插入排序基本思想 設在資料表中有乙個元素序列v 0 v 1 v 2 v n 其中v 0 v 1 v 2 v i 1 是已經排好序的元素。在插入v i 利用折半搜尋尋找v i 的插入位置。二分插入排序是一種穩定的排序。當n較大時,總排序碼比較次數比直接插入排序的最差情況好得多,但比最好情況...