排序 插入排序

2022-07-13 18:42:19 字數 1501 閱讀 8523

插入排序就是把n個元素看成乙個有序表(一般是第乙個元素)和無序表,將無序表中的元素逐個取出和有序表的元素從後向前進行比較,並放入合適的位置

3、**逐步實現

目標:對陣列內元素排序

int arr=;

//

第一輪int insertval=arr[1]; //

預設arr[0]是有序元素,arr[1]是待插入元素

int insertindex=1-1; //

指向待插入元素的前乙個元素

//insertindex>=0是為了防止在找插入位置時發生錯誤, insertvalwhile (insertindex>=0 && insertval

arr[insertindex+1]=insertval; //

跳出迴圈說明插入位置已經找到,為其賦值,為什麼+1,因為迴圈內已經-1,現在才定位到arr[0]

system.out.println(arrays.tostring(arr));

//

第二輪 insertval=arr[2]; //

已經排好兩個元素了,現在需要插入的時第三個元素

insertindex=2-1; //

定位到第三個元素的前乙個元素

while (insertindex>=0 && insertval

arr[insertindex+1]=insertval;

system.out.println(arrays.tostring(arr));

//

第三輪 insertval=arr[3];

insertindex=3-1;

while (insertindex>=0 && insertval

arr[insertindex+1]=insertval;

system.out.println(arrays.tostring(arr));*/

可發現上面幾輪有很多重複**,可以設定乙個for迴圈,整合一下

for (int i=1;i//

i為每次需要插入的元素

int insertval=arr[i];

int insertindex=i-1;

while (insertindex>=0 && insertval

arr[insertindex+1]=insertval;

system.out.println(arrays.tostring(arr));

}

兩層迴圈,所以時間複雜度為o(n^2)

當元素前面時有序,最後幾位為亂序時,很浪費時間,如

int arr=;
7、8、9都是有序,因為最後一位,需要都進行一次排序比較,所以又有了下面的  希爾排序

插入排序 折半插入排序

折半插入排序 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...