排序算法-插入排序

插入排序也是一种常见的排序算法,插入排序的思想是:

将初始数据分为有序部分和无序部分,每一步将一个无序部分的数据插入到前面已经排好序的有序部分中,直到插完所有元素为止。

一、插入排序基本原理

用一个索引值来区分两个区域 排序区 和 未排序区,将 未排序区元素 与 排序区元素 比较,并且插入到合适位置,直到未排序区清空

动画示例:

二、实现代码

将一列数从左到右从小到大排列。

代码如下(示例):

 private static int[] insertionSort(int[] array)
        {
            //遍历右边未排序区的数,n个数遍历n-1次(左边第一个默认已排序)
            for (int unsorted = 1; unsorted < array.Length; unsorted++)
            {
                int temp = array[unsorted];//取下未排序区的第一个数
                //从排序区的最后一个数开始依次往前
                for (int sorted = unsorted - 1; sorted >= 0; sorted--)
                {
                    if (temp < array[sorted])//找到目标位置,满足条件插入排序区
                    {
                        array[sorted + 1] = array[sorted];
                        array[sorted] = temp;
                    }
                    else
                        break;
                }                
            }
            return array;
        }

注意:sorted >= 0是到第一个数为止,sorted--是从后往前。

---

总结

插入排序关键点:

两层循环,外循环代表有n个数进行n-1轮,内循环是将未排序区的数与已排序区的数从后往前依次比较。

稳定性:在使用插入排序时,元素从无序部分移动到有序部分时,必须是不相等(大于或小于)时才会移动,相等时不处理,所以直接插入排序是稳定的。

时间复杂度:插入排序在平均情况运行时间与最坏情况运行时间一样,是O(n^2)

适用性:待排序序列的元素个数不多(<=50),且元素基本有序。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值