插入排序原理及程序实现

基本理念: 一个数组中的每个元素与前面的元素比较,如果前面那一个大,那么继续向前比较,直到找到比这个元素小的数,并排在它后面。

插入排序是从第1个数(不是第0个,因为第0个算是已经排好顺序了) ,逐个与前面的一个数比较,如果第i小,则与第i-1个熟进行交换,直到前面的那个数比它小,然后将前面那个数的位置i-1再+1,得到正确的位置。

#include "../utils.h"

void insertion_sort(int arr[], int len)
{
    int i, j, key;
    for (i = 1; i < len; i++)
    {
        key = arr[i];
        // 往后挪动比key小的值
        for (j = i; j >= 1 && key < arr[j - 1]; j--)
            arr[j] = arr[j - 1];
        // 将key放到正确位置
        arr[j] = key;
    }
}

int main(int argc, char const *argv[])
{
    test(&insertion_sort);
    return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值