数据结构-排序算法之插入排序

直接插入排序

一、算法基本思想

直接插入排序是插入排序的一种,记录array[0,len-1]已经排好序。即array[0]<array[1]<array[2].......array[len-1],将记录计入arrry,插入到上述序列中的适当的位置,使得序列有序。

二、算法流程

  • 待排序数组array[0,len-1].初始时,array[0]自成有序区,array[1,len-1]无序;
  • 第一趟直接插入排序:将array[1]与array[0]进行比较,若array[1]<array[0],则将array[0]与array[1]交换位置;
  • 第i趟直接插入排序:将待插入记录与array[i]与有序数组array[0—i-1]进行比较,进行遍历一遍,如果array[j]《array[i]

则进行交换。 

  • 按上述的方法插入,直到将array[len-1]插入有序的序列之中。 

三、算法实现 

void insertSort(int *arr,int len){
     int i;
     int j;
     int temp;  //定义一个临时变量,用于交换数据时存储 
     for(i=1;i<len;i++){  //因为我们要对该待排序列的每一个元素都和前面的已排好序的序列进行插入,所以我们会对序列进行遍历 
         for(j=0;j<i;j++){  //第二层循环主要用于对已排好序的序列进行扫描,和要插入进来的数据进行逐一比较,然后决定插入到哪里 
             if(*(arr+j)>*(arr+i)){//从前往后对已排好序的元素和待插入元素进行大小比较,然后直到找到一个元素比被插入元素大,则交换位置 
                 temp=*(arr+j);
                *(arr+j)=*(arr+i);
                *(arr+i)=temp;
            }
         }
     }
 }

四、总结

算法的执行过程比较清晰,比较容易实现。当待排序的记录数量比较小时,使用这种算法比较好。但是当排序记录的数量比较大时就不宜用这种方法。

时间复杂度:   O(n2);

空间复杂度:    O(1);

     稳定性:稳定排序。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值