当前位置: 首页 > news >正文

【数据结构】排序算法系列——插入排序(附源码+图解)

插入排序

算法思想

插入排序的算法思想其实很容易理解,它秉持着一个不变的循环:比较->交换->比较->交换…因为我们排序最终的目的是要得到递增或者递减的数据,那么在原有的数据中,我们可以将数据依次两两进行比较:

  • 如果是升序,那么就将较小的放在较大的前面
  • 如果是降序,那么就将较大的放在较小的前面

图解

请添加图片描述

我们看图解中,单次比较过程中,拿出来比较的数只会同它左侧的数进行比较,而被比较的数随着比较结束也会根据具体情况向后移动或者是进行交换,向后移动的过程也称为——补位。在全程的比较中,随着补位和交换的进行,进行比较操作的数只会与曾经进行过比较操作的数进行比较——简单来说,就是比较与被比较是交替进行的。我们总结插入排序算法的核心思路——将待排列元素划分为「已排序」和「未排序」两部分,每次从「未排序的」元素中选择一个插入到「已排序的」元素中的正确位置。

C语言代码分析

//升序情况
void InsertSort(int* arr, int n)
{int end = n - 1;//从最后一个数据开始进行比较int tmp = arr[end];//保存最后一个数据while (end >= 0){if (tmp <= arr[end])//当tmp小于等于arr[end]时,说明tmp还没有找到合适的位置{arr[end + 1] = arr[end];//那么就将arr[end]向后移动end--;//继续向前比较}else//当tmp大于arr[end]时,说明tmp已经找到了合适的位置{break;//那么就直接退出循环}}arr[end + 1] = tmp;
}//降序情况
void InsertSort2(int* arr, int n)
{int begin = 0;//从第一个数据开始进行比较int tmp = arr[begin];//保存第一个数据while (begin <= n - 1){if(tmp>=arr[begin])//当tmp大于等于arr[begin]时,说明tmp还没有找到合适的位置{arr[begin - 1] = arr[begin];//那么就将arr[begin]向后移动begin++;//继续向后比较}else//当tmp小于arr[begin]时,说明tmp已经找到了合适的位置{break;//那么就直接退出循环}arr[begin + 1] = tmp;
}

在现实生活中,扑克牌的排序事实上就是遵循着插入排序的思想:

在这里插入图片描述

时间复杂度

  • 插入排序的最优时间复杂度为O(n),在数列几乎有序时效率很高。

  • 插入排序的最坏时间复杂度和平均时间复杂度都为O(n2)

稳定性

鉴于插入排序不会改变前后元素的相对位置,所以: 稳定

http://www.lryc.cn/news/430664.html

相关文章:

  • TOMATO靶机漏洞复现
  • 高基数 GroupBy 在 SLS SQL 中的查询加速
  • TP5队列和TP5 使用redis 等相关
  • 【R语言速通】1.数据类型
  • 【C++设计模式】(三)创建型模式:单例模式
  • 基于Android Studio的行程记录APK开发指南(三)---界面设计及两种方法获取用户位置
  • 大厂趋势:低代码不等于低能力,赋能高效开发新纪元
  • CentOS全面停服,国产化提速,央国企信创即时通讯/协同门户如何选型?
  • 如何确定Kubernetes是在采用哪种方式进行部署的?
  • 【PostgreSQL】地理空间数据的数据类型定义、索引优化、查询优化策略
  • RocketMQ广播消费消息
  • C#基础(2)枚举
  • Linux之MySQL日志
  • Redis集群模式—主从集群、哨兵集群、分片集群
  • 并发工具类(二):CyclicBarrier
  • Spring Cloud全解析:负载均衡之Ribbon简介
  • Kettle安装与使用指南
  • 教育行业解决方案:智能PPT在教育行业的创新应用
  • Matlab程序练习
  • cesium可不可以改变影像底图颜色,如何给地球底图影像添加一层滤镜蒙版?
  • MyBatis-MappedStatement什么时候生成?QueryWrapper如何做到动态生成了SQL?
  • Netty系列-2 NioServerSocketChannel和NioSocketChannel介绍
  • 智能客服的四大优势,提升企业服务效率
  • AutoGPT开源项目解读
  • Linux离线安装fontconfig
  • 海山数据库(He3DB)+AI:(一)神经网络基础
  • CSS中选择器有哪些?(史上最全选择器)
  • 本地部署 AI 智能体,Dify 搭建保姆级教程(下):知识库 RAG + API 调用,我捏了一个红楼解读大师
  • HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 答案纯享版
  • 基于PHP的文件包含介绍