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

 更新时间:2023年10月31日 09:34:00   作者:大庆指针  
这篇文章主要介绍了C++排序算法之插入排序解析,将数组分为有序表和无序表,每次从有序表中取出一个元素,插入到有序表的适当位置,每遍历一次,有序表中元素增加一个,无序表中元素个数减少一个,重复n-1次,完成排序,需要的朋友可以参考下

C++插入排序

思想

将数组分为有序表和无序表,每次从有序表中取出一个元素,插入到有序表的适当位置,刚开始有序表中只有一个数,无序表中有n-1个数。

每遍历一次,有序表中元素增加一个,无序表中元素个数减少一个,重复n-1次,完成排序。

代码

#include<iostream>
#include<vector>
using namespace std;
void insertSort(vector<int>&vec, int n)
{
	//j表示无序表第一个元素下标
	for (int j = 1; j <n; j++)
	{
		//i表示有序表最后一个元素下标
		for (int i = j - 1; i >= 0; i--)
		{
			if (vec[i] > vec[i + 1])
			{
				swap(vec[i], vec[i + 1]);
			}
		}
	}
}
int main()
{
	vector<int>vec = { 2,3,5,8,9,7,4,6,1 };
	insertSort(vec, vec.size());
	for (auto it : vec)
	{
		cout << it << " ";
	}
	return 0;
}

解析

时间复杂度:

最好时间复杂度(全部有序):O(n)

比较n-1趟,每一趟比较一次,不移动元素,最好时间复杂度为O(n)

最坏时间复杂度(全部逆序):O(n2)

第一次排序时有序表1个元素,无序表n-1个元素,比较1次,移动1次

第二次排序时有序表2个元素,无序表n-2个元素,比较2次,移动2次

...

第n-1次排序时有序表n-1个元素,无序表1个元素,比较n-1次,移动n-1次

故最坏时间复杂度为O((1+2+3+...+n-1)*2)=O(n*(n-1))=O(n2)

空间复杂度:

在原数组上操作,即使用了常数级空间O(1)

稳定性:稳定

到此这篇关于C++排序算法之插入排序解析的文章就介绍到这了,更多相关C++插入排序内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vs2019+Qt+Opencv环境配置心得(图文)

    Vs2019+Qt+Opencv环境配置心得(图文)

    这篇文章主要介绍了Vs2019+Qt+Opencv环境配置心得(图文),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08
  • Qt5实现qDebug日志信息写入日志文件过程

    Qt5实现qDebug日志信息写入日志文件过程

    这篇文章主要为大家介绍了Qt5实现qDebug日志信息写入日志文件的过程示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-05-05
  • C++使用alsa库实现播放声音文件

    C++使用alsa库实现播放声音文件

    这篇文章主要为大家详细介绍了Linux系统上C++如何使用alsa库播放声音文件,文中示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下
    2024-04-04
  • C语言实现字符转unix时间戳的简单实例

    C语言实现字符转unix时间戳的简单实例

    下面小编就为大家带来一篇C语言实现字符转unix时间戳的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-06-06
  • C++ std::Set<std::pair>的实现示例

    C++ std::Set<std::pair>的实现示例

    本文主要介绍了C++ std::Set<std::pair>的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-10-10
  • C++之内存分区的实现示例

    C++之内存分区的实现示例

    本文主要介绍了C++之内存分区的实现示例,主要包含了4个区域,分为代码区,全局区,栈区和堆区,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧
    2024-03-03
  • 基于C语言string函数的详解

    基于C语言string函数的详解

    本篇文章是对C语言中string函数进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • c++实现跳跃表(Skip List)的方法示例

    c++实现跳跃表(Skip List)的方法示例

    跳表(skiplist)是一个非常优秀的数据结构,实现简单,插入、删除、查找的复杂度均为O(logN),下面这篇文章主要介绍了c++实现跳跃表(Skip List)的相关资料,需要的朋友可以参考借鉴,下面随着小编来一起学习学习吧。
    2017-09-09
  • OLEDB打开Excel文件的实现方法

    OLEDB打开Excel文件的实现方法

    下面小编就为大家带来一篇OLEDB打开Excel文件的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • C/C++开发中extern的一些使用注意事项

    C/C++开发中extern的一些使用注意事项

    这篇文章主要为大家介绍了C/C++开发中extern一些使用注意事项的事例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-01-01

最新评论