深入浅析插入排序:原理、实现与应用

在众多基础排序算法中,插入排序以其简洁明了的逻辑和直观的实现方式,赢得了广大程序员的喜爱。本篇博客将带领大家深入了解插入排序的原理、详细实现步骤以及其在实际场景中的应用,帮助读者更好地理解和掌握这一经典排序方法。

一、插入排序原理

插入排序的基本思想是将待排序的元素序列看作是一个有序序列和一个无序序列的组合。初始时,有序序列仅包含一个元素,即第一个元素,其余为无序序列。然后,每次从无序序列中取出一个元素,将其按大小插入到有序序列的适当位置,使之成为新的有序序列。这个过程重复进行,直到无序序列为空,整个序列变为有序。

简单来说,插入排序就像是玩一副扑克牌,我们手中握有一部分已经按顺序排列好的牌(有序序列),然后不断从剩余的牌堆(无序序列)中抽出一张牌,插入到手中的牌序列中正确的位置,使得手中的牌始终保持有序。随着抽取次数的增加,最终整副牌都将按照升序排列。

二、插入排序实现步骤

以下为插入排序的详细实现步骤:

1. 初始化 将数组的第一个元素视为已排序序列,后续元素视为待插入序列。

2. 选择待插入元素 从第二个元素开始,依次选择待插入元素。

3. 插入操作 对于当前待插入元素,与已排序序列中的元素从右向左逐个比较,找到第一个小于或等于待插入元素的位置。

4. 移动元素 将该位置及其右侧的所有元素向右移动一位,腾出空位给待插入元素。

5. 插入待插入元素 将待插入元素插入到上述空位中。

6. 重复步骤2-5 继续选择下一个待插入元素,重复以上插入操作,直至所有元素均被处理。

以下是插入排序算法的代码:

Python

def insertion_sort(arr):  # 遍历从1到数组长度的每个元素  for i in range(1, len(arr)):  # 当前需要排序的元素  key = arr[i]  # 将 key 与已排序的元素进行比较  j = i - 1  while j >= 0 and key < arr[j]:  # 如果 key 更小,则将已排序的元素后移  arr[j + 1] = arr[j]  # 移动指针  j -= 1  # 找到 key 的正确位置,并插入  arr[j + 1] = key  return arr  # 示例  
arr = [12, 11, 13, 5, 6]  
print("原始数组:", arr)  
sorted_arr = insertion_sort(arr)  
print("插入排序后的数组:", sorted_arr)

三、插入排序的时间复杂度与空间复杂度

时间复杂度: 在最好情况下(输入数组已完全有序),插入排序只需要进行一次比较,无需进行元素移动,时间复杂度为O(n)。在最坏情况下(输入数组逆序),需要进行n(n-1)/2次比较和n(n-1)/2次元素移动,时间复杂度为O(n^2)。平均情况下,插入排序的时间复杂度也为O(n^2)。

空间复杂度: 插入排序是原地排序算法,仅需常数级别的额外空间用于临时存储元素,因此空间复杂度为O(1)。

四、插入排序的应用与优化

尽管插入排序在处理大规模数据时效率较低,但在特定场景下仍具有较高的实用价值:

1. 小规模数据排序: 当待排序数据量较小(如n<10)时,插入排序由于其简单直接的实现方式,可能比更复杂的排序算法(如快速排序、归并排序等)更快。

2. 部分有序数据排序: 如果待排序数据接近有序,插入排序的性能会显著提升。在这种情况下,可以考虑使用二分插入排序,通过二分查找确定待插入位置,进一步提高效率。

3. 稳定性需求: 插入排序是一种稳定的排序算法,即相等元素的相对顺序不会改变。在对稳定性有要求的场景中,插入排序是合适的选择。

4. 外部排序: 在无法一次性将所有数据加载到内存的外部排序场景中,插入排序常作为合并排序阶段的辅助排序算法。

总的来说,插入排序虽看似简单,却蕴含着丰富的算法思想。理解并熟练运用插入排序,不仅能提升编程技能,更能为后续学习更复杂的排序算法打下坚实的基础。希望这篇博客能帮助您深入理解插入排序,使其成为您的算法工具箱中的一把利剑。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/808229.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

用python 实现进销存

进销存系统是一个基本的商业管理系统&#xff0c;用于跟踪库存、销售和采购活动。以下是一个简单的进销存系统的Python实现&#xff0c;这个系统包括商品管理、采购入库、销售出库以及库存查询的功能。 首先&#xff0c;我们定义一个Product类来表示商品&#xff1a; python复…

Unity3D知识点精华浓缩

一、细节 1、类与组件的关系 2、Time.deltaTime的含义 3、怎么表示一帧的移动距离 4、Update和LateUpdate的区别和适用场景 5、找游戏对象的方式&#xff08;别的对象 / 当前对象的子对象&#xff09; 6、组件1调用组件2中方法的方式 7、在面板中获取外部数据的方法 8、序列化属…

在Windows系统中开启SSH服务

文章目录 引言I 使用Windows内置的OpenSSH服务器功能1.1 安装并启用SSH服务器1.2 配置SSH服务器的端口号II Windows的run功能III SSH的其他操作3.1 绑定本地端口3.2 本地端口转发3.3 远程端口转发3.4 后台运行3.5 不执行远程操作3.6 在Linux上创建一个git用户用于SSH访问see al…

ChatGPT智能写作:开启论文写作新视野

ChatGPT无限次数:点击直达 html ChatGPT智能写作&#xff1a;开启论文写作新视野 引言 在当今信息爆炸的时代&#xff0c;人们需要更有效的工具来帮助他们在各种领域进行写作。ChatGPT作为一项基于人工智能技术的顶尖产品&#xff0c;为论文写作提供了全新的视角和可能性。…

海外博士后政策,这些重点你不能错过!

​ ​海外高层次人才博士后专项申报政策是针对具有较高学术造诣和研究潜力的海外学者、研究人员&#xff0c;旨在吸引他们回国从事科研工作&#xff0c;推动国内科技创新发展。该政策不仅为海外人才提供了良好的职业发展平台&#xff0c;还为他们提供了丰富的科研资源和优厚…

20240408在线给加密的PDF文件解密【打印限制】

20240408在线给加密的PDF文件解密 百度&#xff1a;PDF解密 https://smallpdf.com/cn/unlock-pdf PDF解密 未选择任何文件 或拖放PDF至此处 无文件大小限制&#xff0c;无广告水印 - 这款易于使用且免费的在线密码移除工具可为您移除恼人的PDF密码。 无需注册 数秒内解锁 PDF …

【GitHub技术全面解析及游戏开发者的应用】

GitHub技术全面解析及游戏开发者的应用 GitHub作为全球最大的开源代码托管平台&#xff0c;不仅为软件开发者提供了一个强大的工具&#xff0c;也为游戏开发者带来了前所未有的便利。在游戏开发领域&#xff0c;GitHub的技术可以帮助开发者更高效地管理代码、协作开发、分享资…

CommandLineRunner实现项目启动时预处理

如果希望在SpringBoot应用启动时进行一些初始化操作可以选择使用CommandLineRunner来进行处理。 我们只需要实现CommandLineRunner接口&#xff0c;并且把对应的bean注入容器。把相关初始化的代码重新到需要重新的方法中。 这样就会在应用启动的时候执行对应的代码。 Compon…

python基础语法--输入和输出

一、 输入 input() python使用input输入变量&#xff0c;input输入的变量为字符串形式&#xff0c;可以通过其他方式转换为整型或其他类型。 &#xff08;1&#xff09;单行读入已知个数的字符串或数字 读入字符串 # 单行读入字符串a,并给出一句输入提示 a input("请…

【随笔】Git 高级篇 -- 提交的技巧(下) cherry-pick commit --amend(十九)

&#x1f48c; 所属专栏&#xff1a;【Git】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢迎大…

Vue插件使用详细介绍

介绍​ 插件 (Plugins) 是一种能为 Vue 添加全局功能的工具代码。下面是如何安装一个插件的示例&#xff1a; import { createApp } from vueconst app createApp({})app.use(myPlugin, {/* 可选的选项 */ }) 一个插件可以是一个拥有 install() 方法的对象&#xff0c;也可以直…

pose_iter_116000.caffemodel 下载地址(github)

没有百度云会员&#xff0c;github上几秒就下完了 face&#xff1a;pose_iter_116000.caffemodelhttps://github.com/ihp-lab/OpenSense/blob/fefe13ccf250e4811f4f61edf0b212e4ded78d19/Interoperations/OpenPose.PInvoke/OpenPoseLib/models/face/pose_iter_116000.caffemode…

搭建网站的步骤

搭建网站的步骤 我们选择了白嫖雨云的二级域名 浏览器输入https://www.rainyun.com/z22_ 创建账号然后选择一个你喜欢的子域名我建议后缀选择ates.top的 选择自定义地址&#xff0c;类型选择cname 现在要选择记录值了&#xff0c;有a&#xff0c;aa&#xff0c;txt等 根据实际…

加速度JUSDO | 电子元器件商城行业调研及运营方案

一、行业背景与竞品分析 随着电子元器件行业的快速发展&#xff0c;线上元器件商城已成为行业交易的重要渠道。目前市场上存在多个知名的元器件商城&#xff0c;如立创、云汉芯城、贸泽商城等&#xff0c;它们都提供了丰富的元器件产品和便捷的线上交易服务。 立创商城&#x…

1200/天,长期兼职贵么?

今天收到一个客户询盘&#xff0c;问公司长期招聘一个兼职程序员&#xff0c;包月的这种。问我多少钱一个月&#xff0c;在这种需求未明确的情况下&#xff0c;单纯的问价格其实意义不大的&#xff0c;只要报价不在客户心理预期范围内基本没戏的。 关于定价 关于程序员价格的定…

MySQL-----索引

一 概述 索引(index)是帮助MysQL高效获取数据的数据结构(有序)。在数据之外&#xff0c;数据库系统还维护着满足特定查找算法的数据结构&#xff0c; 这些数据结构以某种方式引用&#xff08;指向&#xff09;数据&#xff0c;这样就可以在这些数据结构上实现高级查找算法&…

Excel 记录单 快速录入数据

一. 调出记录单 ⏹记录单功能默认是隐藏的&#xff0c;通过如下如图所示的方式&#xff0c;将记录单功能显示出来。 二. 录入数据 ⏹先在表格中录入一行数据&#xff0c;给记录单一个参考 ⏹将光标至于表格右上角&#xff0c;然后点击记录单按钮&#xff0c;调出记录单 然后点…

[目标检测] OCR: 文字检测、文字识别、text spotter

概述 OCR技术存在两个步骤&#xff1a;文字检测和文字识别&#xff0c;而end-to-end完成这两个步骤的方法就是text spotter。 文字检测数据集摘要 daaset语言体量特色MTWI中英文20k源于网络图像&#xff0c;主要由合成图像&#xff0c;产品描述&#xff0c;网络广告(淘宝)MS…

Kali系统开启SSH服务结合内网穿透工具实现无公网IP远程连接

文章目录 1. 启动kali ssh 服务2. kali 安装cpolar 内网穿透3. 配置kali ssh公网地址4. 远程连接5. 固定连接SSH公网地址6. SSH固定地址连接测试 本文主要介绍如何在Kali系统编辑SSH配置文件并结合cpolar内网穿透软件&#xff0c;实现公网环境ssh远程连接本地kali系统。 1. 启…

Java特性之设计模式【外观模式】

一、外观模式 概述 外观模式&#xff08;Facade Pattern&#xff09;隐藏系统的复杂性&#xff0c;并向客户端提供了一个客户端可以访问系统的接口。这种类型的设计模式属于结构型模式&#xff0c;它向现有的系统添加一个接口&#xff0c;来隐藏系统的复杂性 这种模式涉及到一…