插入排序的基本操作是「有序插入」,也就是將元素按照大小的排布逐一插入到乙個有序的陣列中。對於陣列a[n]通常認為a[0]為長度為1的有序陣列,然後按照有序插入法,將後面的陣列元素逐一插入到有序組中,這樣一來,有序組的長度將不斷增長,最後到達整個陣列的長度,即整個陣列為有序組,至此排序完成。
如陣列:[ 3 2 5 1 9] 進行直接插入排序的情況如下(加粗部分為有序序列):
[32 5 1 9 ]
[2 35 1 9 ]
[2 3 51 9 ]
[1 2 3 59 ]
[1 2 3 5 9]
c語言實現**如下:
void
inert_sort
(int arr,
int len)
arr[j +1]
= temp;
//插入有序表中
}}
直接插入排序演算法
直接插入演算法 有乙個已經有序的資料序列,要求在這個已經排好的資料序列中插入乙個數,但要求插入後此資料序列仍然有序,這個時候就要用到一種新的排序方法 插入排序演算法,插入排序的基本操作就是將乙個資料插入到已經排好序的有序資料中,從而得到乙個新的 個數加一的有序資料,演算法適用於少量資料的排序,時間複...
直接插入排序演算法
撲克牌是我們幾乎每個人都可能從事過的遊戲。而最基本的撲克玩法都是一邊摸牌,一邊理牌。假如我們拿到了這樣一手牌,如圖9 5 1。啊,似乎是同花順呀,別急,我們得理一理順序才知道是否是真的同花順。請問,如果是你,應該如何理牌呢?應該說,哪怕你是第一次玩撲克牌,只要認識這些數字,理牌的方法都是不用教的。將...
直接插入排序演算法
每次將乙個待排序的記錄按其關鍵字的大小插到前面已經排序的序列中的適當位置,直到全部記錄插入完畢為止。第一趟比較前兩個數,然後把第二個數按大小插入到有序表中 第二趟把第三個資料與前兩個數從後向前掃瞄,把第三個數按大小插入到有序表中 依次進行下去,進行了 n 1 趟掃瞄以後就完成了整個排序過程。將待插入...