现在的位置: 首页 > 综合 > 正文

直接插入排序

2013年10月02日 ⁄ 综合 ⁄ 共 536字 ⁄ 字号 评论关闭

直接插入排序(straight insertion sort)的作法是:

  每次从无序表中取出第一个元素,把它插入到有序表的合适位置,使有序表仍然有序。   

第一趟比较前两个数,然后把第二个数按大小插入到有序表中; 第二趟把第三个数据与前两个数从后向前扫描,把第三个数按大小插入到有序表中;依次进行下去,进行了(n-1)趟扫描以后就完成了整个排序过程。  直接插入排序属于稳定的排序,时间复杂性为o(n^2),空间复杂度为O(1)。   直接插入排序是由两层嵌套循环组成的。外层循环标识并决定待比较的数值。内层循环为待比较数值确定其最终位置。直接插入排序是将待比较的数值与它的前一个数值进行比较,所以外层循环是从第二个数值开始的。当前一数值比待比较数值大的情况下继续循环比较,直到找到比待比较数值小的并将待比较数值置入其后一位置,结束该次循环。

 

for(i=1,i<n;++i)
{
 int temp=a[i]; //要比较的在有序序列之外的那个数:
temp
 for(j=i;j>0&&temp<a[j-1];--j)
 {  //
temp比序列内的数小,序列内的数前移
  a[j]=a[j-1]; 
 
 }
 a[j]=temp;//
temp比序列里的数大了,这就是temp该在的位置了
}

 

 

 


抱歉!评论已关闭.