iOS算法之插入排序

插入排序就是每一步都将一个待排数据按其大小插入到已经排序的数据中的适当位置,直到全部插入完毕。 插入排序方法分直接插入排序和折半插入排序两种。

详细代码请参考Algorithm。参考代码比文字好理解。

时间复杂度与空间复杂度

时间复杂度:O(n^2)
空间复杂度:O(1)

最少比较次数:(已排序的数组)n-1次
最多比较次数:(降序的数组)n(n-1)/2次

数组在已排序或者是“近似排序”时,插入排序效率的最好情况运行时间为O(n);插入排序最坏情况运行时间和平均情况运行时间都为O(n^2) 。

插入排序不适合对大量数据排序,适合对接近排序的数据排序。插入排序是稳定排序。通常,插入排序呈现出二次排序算法中的最佳性能。对于具有较少元素(如n<=15)的列表来说,二次算法十分有效。在列表已被排序时,插入排序是线性算法O(n)。在列表“近似排序”时,插入排序仍然是线性算法。在列表的许多元素已位于正确的位置上时,就会出现“近似排序”的条件。

算法描述

假定n是数组的长度,首先假设第一个元素被放置在正确的位置上,这样仅需从1到n-1范围内对剩余元素进行排序。对于每次遍历,从0到i-1范围内的元素已经被排好序,每次遍历的任务是:通过扫描前面已排序的子列表,将位置i处的元素定位到从0到i的子列表之内的正确的位置上。

将arr[i]复制为一个名为target的临时元素。向下扫描列表,比较这个目标值target与arr[i-1]、arr[i-2]的大小,依次类推。这个比较过程在小于或等于目标值的第一个元素(arr[j])处停止,或者在列表开始处停止(j=0)。在arr[i]小于前面任何已排序元素时,后一个条件(j=0)为真,因此,这个元素会占用新排序子列表的第一个位置。在扫描期间,大于目标值target的每个元素都会向右滑动一个位置(arr[j]=arr[j-1])。一旦确定了正确位置j,目标值target(即原始的arr[i])就会被复制到这个位置。与选择排序不同的是,插入排序将数据向右滑动,并且不会执行交换。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 排序算法说明 (1)排序的定义:对一序列对象根据某个关键字进行排序; 输入:n个数:a1,a2,a3,…,an 输...
    code武阅读 3,926评论 0 0
  • Ba la la la ~ 读者朋友们,你们好啊,又到了冷锋时间,话不多说,发车! 1.冒泡排序(Bub...
    王饱饱阅读 5,782评论 0 7
  • 春节期间通过妹妹了解了尚赫,凭着直觉,来南宁后加入了尚赫,我很庆幸找到这样一个平台,我感觉这就是我要追求的事业和生...
    红米若水阅读 4,375评论 0 0
  • 大家踩刹车后会发生什么? 今天所讲的故事就是一脚刹车成就一段跨越千里的浪漫爱情故事。 且听我慢慢道来。...
    诗不在远方阅读 4,239评论 0 2
  • 我每时每刻都有一种冲动, 想要到你身边把我的感觉大声说出来 可是,我还没迈出步伐就想到的过去的种种, 低头,垂眉,...
    南京哭了阅读 1,346评论 0 1

友情链接更多精彩内容