时间:2021-05-20
本文实例为大家分享了C++排序算法之插入排序的具体代码,供大家参考,具体内容如下
1.基本思想:将未排序的数据元素按大小顺序插入到已排好序数据序列中,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
例如:对2, 4, 3, 1, 6, 5进行插入排序。进行排序前,默认2是有序的,为有序区,而4, 3, 1, 6, 5是无序的,为无序区。将这五个无序的数按从小到大的顺序插入到有序区。
第一趟排序:将4与有序区的2比较,若小于2则插到2前面,大于2插到2后面。操作后有序区为:{2,4};
第二趟排序:将3与有序区的每个数比较(与有序区的数按从右到左的顺序比较,即依次与4,2比较),寻找合适的位置插入,操作后有序区为:{2,3,4}。这里将3插入到2和4之间。
……
第五趟排序:将数据元素5与有序区的数据进行比较,并插入到有序区,则排序后的数据序列为:{1,2,3,4,5,6}。
总结:
1.第一趟排序时默认无序区的第一个数据元素是有序的;
2.从以上例子可以看出,若对n个数进行排序,需要进行(n-1)趟。
2.代码:
3.时间复杂度分析:若将待排序的数据元素按从小到大的顺序排序,可分为最好情况和最坏情况讨论。
(1).最好的情况:最好的情况就是待排序的数据已经排好序了,这时只需要进行(n-1)次比较操作。
(2).最坏的情况:最坏的情况就是待排序的数据序列是逆序的。此时需要进行的比较次数为n(n-1)/2次,赋值操作是比较操作的次数n(n-1)/2+(n-1)次。平均来说插入排序算法的时间复杂度为O(n^2)。
注:插入排序不适合对于数据量比较大的排序应用
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C++算法之希尔排序算法详解及实例希尔排序算法定义:希尔排序是插入排序的一种,也称缩小增量排序,是直接插入排序算法的一种更高效的改进版本。算法思想:希尔排序是把
本文实例讲述了C语言基本排序算法之插入排序与直接选择排序实现方法。分享给大家供大家参考,具体如下:声明待排序元素类型/*--------------------
本文实例讲述了Java排序算法总结之希尔排序。分享给大家供大家参考。具体分析如下:前言:希尔排序(ShellSort)是插入排序的一种。是针对直接插入排序算法的
本文实例讲述了Python排序搜索基本算法之插入排序。分享给大家供大家参考,具体如下:插入排序生活中非常常见,打扑克的时候人的本能就在用插入排序:把抽到的一张插
希尔排序,也称递减增量排序算法,是插入排序的一种更高效的改进版本。但希尔排序是非稳定排序算法。希尔排序是基于插入排序的以下两点性质而提出改进方法的:插入排序在对