直接插入排序(Insertion Sort)的基本思想是:每次將一個待排序的記錄,按其關鍵字大小插入到前面已經排好序的子序列中的適當位置,直到所有記錄插入完成爲止。算法
這個算法比較簡單,不須要過多的解釋,代碼以下:測試
1 /* 2 * insert the value which is at the index index in data 3 */ 4 void insert_sort(int *data, int index, int value) 5 { 6 int temp_index = index; 7 for(int i = 0;i < index;++i) 8 { 9 //find the first value that bigger than the passed value 10 if(value < data[i]) 11 { 12 temp_index = i; 13 break; 14 } 15 } 16 17 int temp = index; 18 while(temp > temp_index) //right shift one number from the temp_index 19 data[temp] = data[--temp]; 20 data[temp_index] = value; 21 }
如下是測試:spa
1 int main() 2 { 3 // int data[] = {3,2,6,1,30,-3}; 4 int data[] = {5,4,3,2,1,0}; 5 int length = 6; 6 for(int i = 1;i < length;++i) 7 insert_sort(data,i,data[i]); 8 9 for(int i = 0;i < length;++i) 10 cout << data[i] << " "; 11 cout << endl; 12 return 0; 13 }
結果以下:code