C++排序算法之插入排序

 更新时间:2019年08月21日 08:43:26   作者:墨上烟雨  
这篇文章主要为大家详细介绍了C++排序算法之插入排序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了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.代码:

#include<iostream>

using namespace std;

void insertion_sort(int a[], int len)
{
 int i, j, temp;
 for (i = 1; i < len; i++) //控制趟数
 {
 temp = a[i];
 for(j = i; j > 0 && temp < a[j-1]; j--) // 无序区的数据与有序区的数据元素比较
 {
  a[j] = a[j-1]; //将有序区的元素后移
 }
 a[j] = temp;
 }
}

int main()
{
 int a[] = {2, 4, 3, 1, 6, 5};

 insertion_sort(a, 6);

 for (int i = 0; i < 6; i++)
 {
 cout << a[i] << " ";
 }

 return 0;
}

3.时间复杂度分析: 若将待排序的数据元素按从小到大的顺序排序,可分为最好情况和最坏情况讨论。

(1).最好的情况:最好的情况就是待排序的数据已经排好序了,这时只需要进行(n-1)次比较操作。
(2).最坏的情况:最坏的情况就是待排序的数据序列是逆序的。此时需要进行的比较次数为n(n-1)/2次,赋值操作是比较操作的次数n(n-1)/2+(n-1)次。平均来说插入排序算法的时间复杂度为O(n^2)。

注:插入排序不适合对于数据量比较大的排序应用

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言return知识点总结

    C语言return知识点总结

    在本篇文章里小编给大家整理的是关于C语言return知识点总结内容,需要的朋友们可以学习参考下。
    2020-02-02
  • C++有限状态机实现详解

    C++有限状态机实现详解

    这篇文章主要为大家详细介绍了C++有限状态机的相关资料,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • 浅析_tmain()与main()的区别

    浅析_tmain()与main()的区别

    _tmain()是为了支持unicode所使用的main一个别名,既然是别名,应该有宏定义过的,在哪里定义的呢?就在那个让你困惑的<stdafx.h>里
    2013-03-03
  • C语言超详细讲解文件的操作

    C语言超详细讲解文件的操作

    C语言文件操作的方法有很多,函数也有很多你知道哪些呢?下面是小编为大家带来的C语言文件操作的方法,欢迎阅读
    2022-04-04
  • 快速解决boost库链接出错的问题(分享)

    快速解决boost库链接出错的问题(分享)

    下面小编就为大家带来一篇快速解决boost库链接出错的问题(分享)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • C语言新手练习之多维数组、结构体及函数

    C语言新手练习之多维数组、结构体及函数

    这篇文章主要给大家介绍了关于C语言新手练习之多维数组、结构体及函数的相关资料,这些内容在我们日常开发中经常会遇到的,需要的朋友可以参考下
    2021-06-06
  • Visual Studio 2019配置OpenCV4.1.1详细图解教程

    Visual Studio 2019配置OpenCV4.1.1详细图解教程

    这篇文章主要介绍了Visual Studio 2019配置OpenCV4.1.1详细图解教程 ,需要的朋友可以参考下
    2020-02-02
  • C++实现有向图的邻接表表示

    C++实现有向图的邻接表表示

    这篇文章主要为大家详细介绍了C++实现有向图的邻接表表示,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • 详解C++ 引用

    详解C++ 引用

    这篇文章主要介绍了C++ 引用的相关资料,文中示例代码非常详细,帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • Linux下C语言实现贪吃蛇小游戏

    Linux下C语言实现贪吃蛇小游戏

    这篇文章主要为大家详细介绍了Linux下C语言实现贪吃蛇小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03

最新评论