設陣列為a[n],i = 1。
1. a[0..i-1]為有序區,現需要插入a[i]到a[0…i-1]。
2. 用a[i]的值與a[1..n-1]中元素進行大小比較,找到插入位置將a[i]插入,原插入位置上的元素依次後移。
3. i++。若i < n則執行1。否則排序結束。
來自維基百科
陣列s: [9,1,5,3,8,7]
第一趟:[(1,9),5,3,8,7] –index=1
第二趟:[(1,5,9,)3,8,7] –index=2
第三趟:[(1,3,5,9),8,7] –index=3
第四趟:[(1,3,5,8,9),7] –index=4
第五趟:[(1,3,5,7,8,9)] –index=5
public
static
insertsort(int s)}}
def
insert_sort
(s):
#python
for i in range(1, len(s)):
for j in range(i, 0, -1):
if s[j-1] <= s[j]:
break
s[j-1], s[j] = s[j], s[j-1]
插入排序 直接插入排序
直接插入排序演算法思想 將整個資料表分成左右兩個子表,其中左子表為有序表,右子表為無序表 整個排序過程就是將右子表中的元素逐個插入到左子表中,直到右子表為空,而左子表成為新的有序表。演算法過程分析 將待排序的元素存放在陣列r n 1 中,在初始狀態下,r 0 為監視哨,r 1 為有序區,r 2 r ...
插入排序 直接插入排序
一.插入排序的基本思想 將乙個記錄插入已排序好的有序表中,從而得到乙個新的記錄數加1的有序表。要點 設立哨兵,作為臨時儲存和判斷陣列邊界之用。所謂的哨兵,就是即將插入的記錄。二.示例 如果碰見相等的元素,會被插到後面,所以,相等元素的前後順序沒有改變,插入排序是穩定的。三.演算法實現 public ...
插入排序 直接插入排序
直接插入排序的基本思想 將乙個記錄插入到已排序好的有序表中,然後得到乙個新記錄數增1的有序表。也就是 先將序列的第1個記錄看成是乙個有序的子串行,然後從第2個記錄逐個進行插入,直至整個序列有序為止。如果碰見乙個和插入元素相等的,那麼插入元素把想插入的元素放在相等元素的後面。所以,相等元素的前後順序沒...