插入排序(Insertion Sort)的基本思想是
位置
本節介紹兩種插入排序方法
直接插入排序基本思想
假設待排序的記錄存放在數組R[
R[i]插入當前的有序區R[
通常將一個記錄R[i](i=
排序過程的某一中間時刻
序區)
直接插入排序的基本操作是將當前無序區的第
序區
插入排序與打撲克時整理手上的牌非常類似
手的牌(有序區)中正確的位置上
一趟直接插入排序方法
首先在當前有序區R[
置上的空間插入R[i]
注意
若R[i]的關鍵字大於等於R[
一種查找比較操作和記錄移動操作交替地進行的方法
具體做法
將待插入記錄R[i]的關鍵字從右向左依次與有序區中記錄R[j](j=i
① 若R[j]的關鍵字大於R[i]的關鍵字
②若R[j]的關鍵字小於或等於R[i]的關鍵字
關鍵字比R[i]的關鍵字大的記錄均已後移
直接插入排序算法
void lnsertSort(SeqList R)
{ //對順序表R中的記錄R[
int i
for(i=
if(R[i] //應在原有位置上 R[0]=R[i];j=i-1; //R[0]是哨兵,且是R[i]的副本 do{ //從右向左在有序區R[1..i-1]中查找R[i]的插入位置 R[j+1]=R[j]; //將關鍵字大於R[i].key的記錄後移 j-- ; }while(R[0].key R[j+1]=R[0]; //R[i]插入到正確的位置上 }//endif }//InsertSort
From:http://tw.wingwit.com/Article/program/sjjg/201311/23808.html