排序之插入排序

直接插入排序(Straight Insertion Sort)的基本思想是:把n个待排序的元素看成为一个有序表和一个无序表。开始时有序表中只包含1个元素,无序表中包含有n-1个元素,排序过程中每次从无序表中取出第一个元素,将它插入到有序表中的适当位置,使之成为新的有序表,重复n-1次可完成排序过程插入排序排序代码如下
#include "stdio.h"

insertsort(int *array,int max)
{
int i,j;
for( i=1;i < max;i++ )
{
int key = array[i];
j=i - 1;
while(j >= 0 && array[j]> key)
{
array[j+1] = array[j];
j=j-1;
}
array[j+1] = key;
}
}


int main()
{
int i;
int array[]={5,2,3,4,5,6,7,1,9};
int length=sizeof(array)/sizeof(array[0]);
printf("处理之前:\n");
for(i=0;;i
{
printf("%d",array[i]);
}
printf("\n排序之后\n");
insertsort(array,length);
for(i=0;i
{
printf("%d",array[i]);
}
return 0;
}
时间复杂度:
最好O(n);
最坏O(n2);
稳定性:稳定
posted @ 2014-04-01 08:58  dreamsyeah  阅读(124)  评论(0编辑  收藏  举报