IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 208-插入排序算法的思想和性能分析(重要) -> 正文阅读

[数据结构与算法]208-插入排序算法的思想和性能分析(重要)

1、插入排序算法的思想

  • 特点: 从第二个元素开始,把前面的元素序列当作已经有序的,然后找合适的位置插入。
  • 优点: 插入排序是普通排序里面效率最高的排序算法,而且在数据越趋于有序的情况下,插入排序的效
    率是最高的。在这里插入图片描述
    对于插入排序算法来说,不仅仅没有交换,而且比较的次数也少!
    在这里插入图片描述
    插入排序: 每次会把前面的一组序列当做已经排序好的,然后把后面的元素,按照有序的方式插入到前面的序列就可以了。
    在这里插入图片描述
    具体该怎么做呢?

下面这是我们原始的一组待排序的序列。
在这里插入图片描述
我们认为第一个元素25本身就是有序的序列,因为就一个元素25嘛。

我们从第二个元素开始处理:

第1趟: 认为25是有序的序列,然后把40按照顺序插入到其前面已经有序的序列,因为前面已经是有序的序列,所以从40就往前找,找第一个小于或者等于40的数字,插入到其后面。
在这里插入图片描述
现在前面有序的序列是:25,40

第2趟: 处理25这个元素,25前面是有序的序列了,然后25往前找第一个小于或者等于25的元素(维护其稳定性),插入到其后面。

25先和40比,40比25大,把40往后挪:
在这里插入图片描述
在这里插入图片描述
然后25和25比,25==25,就插入到25的后面,保持其稳定性。
在这里插入图片描述
第二趟处理完,前面的有序序列是:25,25,40

现在开始第3趟:
处理元素9,9前面已经是有序的序列了,9往前遍历,寻找第一个小于等于9的元素,插入到其后面
在这里插入图片描述
现在前面有序的序列是:9,25,25,40

现在开始第4趟: 处理元素32,往前找第一个小于等于32的元素
在这里插入图片描述
这一趟只比较了1个元素,就按序插到前面有序的序列中了

在数据量大的情况下,元素越有序,选择排序算法的比较次数越少,效率越高。

第5趟也是如此操作,以此类推下去,直到最后一趟处理最后一个元素为止。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
最后一趟:处理31
在这里插入图片描述
插入排序效率高:

  • 两个元素没有交换过
  • 因为每一趟的待处理元素的前面序列是有序的,所以基本上,比较的次数是比较少的,基本上都一两次,两三次就有序插入OK了,除非在后面处理的数字是非常小的数字,需要比较多次。
  • 所以插入排序的每一趟处理的效率是非常高的,而且处理的步骤是非常少的,很快的。

有时候甚至比较1次就可以:(针对87这个元素)
在这里插入图片描述

2、插入排序算法的代码实现

// 插入排序算法  时间复杂度: 最坏、平均 O(n^2)  最好:O(n)  空间:O(1)  稳定性:稳定的
void InsertSort(int arr[], int size)
{
	for (int i = 1; i < size; i++) // O(n),假设第0个元素是有序的,从第1个元素开始
	//注意: i < size, 最后一个元素要和前面的元素进行比较,插入
	{
		int val = arr[i];
		int j = i - 1;
		for (; j >= 0; j--) // O(n)
		{
			if (arr[j] <= val)		//这个=就决定了算法是稳定性算法
			{
				break;
			}
			arr[j + 1] = arr[j];	//将当前元素一个个向后挪
		}
		arr[j + 1] = val;
	}
}

3、插入排序算法的性能分析

3.1、时间、空间复杂度

时间复杂度:
最坏、平均时间复杂度 O(n^2)
因为是有2个for循环,是嵌套的

最好时间复杂度:O(n)
待排序的序列已经是有序的序列了。
相当于内层循环不做任何数据移动交换,外层循环遍历1遍就完了。

3.2、稳定性

稳定排序!

因为它找的是 前面有序序列中,小于等于它的数字,然后插到其后面
后面的元素是不会跑到前面和它相等的元素的前面的,只会跟在其后面。
在这里插入图片描述

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-16 11:26:44  更:2022-05-16 11:27:45 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 12:53:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码