插入法排序
所謂插入排序法,就是檢查第i個數字,如果在它的左邊的數字比它大,進行交換,這個動作一直繼續下去,直到這個數字的左邊數字比它還要小,就可以停止了。
假設我們輸入的是 “5,1,4,2,3” 我們從第二個數字開始,這個數字是1,我們的任務隻要看看1有沒有正確的位置,我們的做法是和這個數字左邊的數字來比,因此我們比較1和5,1比5小,所以我們就交換1和5,原來的排列就變成了“1,5,4,2,3 ”
接下來,我們看第3個數字有沒有在正確的位置。這個數字是4,它的左邊數字是5,4比5小,所以我們將4和5交換,排列變成了 “1,4,5,2,3 "我們必須繼續看4有沒有在正確的位置,4的左邊是1,1比4小,4就維持不動了。
/********************************************************************** *功能描述:插入法排序 *輸入參數: 數組, 起始索引(0), 終止索引 *輸出參數: 排好序的數組 *返回值: void *其它說明: *修改記錄1: //修改曆史記錄,包括修改日期、版本號、修改人及修改內容等 *修改日期 版本號 修改人 修改內容 * -------------------------------------------------------------------------------------------------- * 20140716 V1.0 wuyq 創建 ***********************************************************************/ void insertion_sort(int array[], int first, int last) { int i,j; int temp; for(i=first+1; i<=last; i++) { temp=array[i]; j=i-1; //與已排序的數逐一比較,大於temp時,該數移後 while((j>=first)&&(array[j]>temp)) { array[j+1]=array[j]; j--; } array[j+1]=temp; } } /********************************************************************** *功能描述:插入法排序 *輸入參數: 數組, 元素個數 *輸出參數: 排好序的數組 *返回值: void *其它說明: *修改記錄1: //修改曆史記錄,包括修改日期、版本號、修改人及修改內容等 *修改日期 版本號 修改人 修改內容 * -------------------------------------------------------------------------------------------------- * 20140716 V1.0 wuyq 創建 ***********************************************************************/ void insert_sort(int* array, unsigned int n) { int i,j; int temp; for(i=1;i<n;i++) { temp=*(array+i); for(j=i;j>0&&*(array+j-1)>temp;j--) { *(array+j)=*(array+j-1); } *(array+j)=temp; } } #include <stdio.h> int main() { int a[8] = {5, 6, 2, 7, 2, 0, 1, 4}; //insertion_sort(a, 0, 7); insert_sort(a, 8); int i; for(i=0; i<8; i++) { printf("%d ", a[i]); } printf("\n"); return 0; }
最後更新:2017-04-03 05:39:27