【算法-插入排序】基础知识,代码示例和应用场景

插入排序是一种相对简单、直观的排序算法,有点类似打扑克牌时将一张张牌“插入”到合适位置的过程。虽然插入排序的效率不如高级排序算法,但它有自己独特的优点,尤其在小数据集或已部分有序的数据中表现出色。


什么是插入排序

插入排序是一种逐步构建有序列表的算法。它将数组分成“已排序部分”和“未排序部分”,然后从未排序部分中挑选元素插入到已排序部分的合适位置。想象打扑克牌时,一张张将牌放在手中按照大小排好,就是插入排序的过程。

插入排序的操作过程

插入排序

假设有一个无序的数组 [8, 4, 3, 7, 6],我们用插入排序把它从小到大排序。

  1. 第一步

    • 假设第一个元素 [8] 已经有序。
    • 从第二个元素开始 [4],插入到 [8] 之前。
    • 结果为 [4, 8, 3, 7, 6]
  2. 第二步

    • 将第三个元素 [3] 插入到 [4, 8] 中。
    • [3][4] 小,放到最前面。
    • 结果为 [3, 4, 8, 7, 6]
  3. 第三步

    • 将第四个元素 [7] 插入到 [3, 4, 8] 中。
    • [7][4] 大,但比 [8] 小,因此插入到 [8] 之前。
    • 结果为 [3, 4, 7, 8, 6]
  4. 第四步

    • 将第五个元素 [6] 插入到 [3, 4, 7, 8] 中。
    • [6][7] 小,所以插入到 [7] 之前。
    • 最终结果为 [3, 4, 6, 7, 8]

通过这样一轮轮的插入,数组逐渐变得有序。


插入排序的代码实现

下面是插入排序的 Java 代码实现,每一步都附带注释,方便理解。

public class InsertionSort {public static void insertionSort(int[] arr) {// 从第二个元素开始逐个插入for (int i = 1; i < arr.length; i++) {int current = arr[i];int j = i - 1;// 向左扫描已排序部分,找到插入位置while (j >= 0 && arr[j] > current) {arr[j + 1] = arr[j]; // 向右移动元素j--;}// 把当前元素插入到合适位置arr[j + 1] = current;}}public static void main(String[] args) {int[] arr = {8, 4, 3, 7, 6};insertionSort(arr);System.out.println(Arrays.toString(arr));}
}

代码运行过程

对于数组 [8, 4, 3, 7, 6],代码运行时会执行以下操作:

  • 第一次循环,i = 1,将 4 插入到 8 前面。
  • 第二次循环,i = 2,将 3 插入到 4 前面。
  • 第三次循环,i = 3,将 7 插入到 8 前面。
  • 第四次循环,i = 4,将 6 插入到 8 前面。

这样一轮轮下来,最终输出的是 [3, 4, 6, 7, 8]


插入排序的时间复杂度

插入排序的时间复杂度取决于数据的有序程度:

  • 最佳情况:当数组已经有序时,插入排序只需逐一比较,无需移动元素,时间复杂度为 (O(n))。
  • 最差情况:当数组完全逆序时,每个元素都需要比较和移动,时间复杂度为 (O(n^2))。
  • 平均情况:在一般随机数据下,插入排序的时间复杂度为 (O(n^2))。

由于其时间复杂度,插入排序并不适合处理大规模数据,但在小数据集或近似有序的场景下表现不错。


插入排序的适用场景

  1. 小型数据集:对于数量较少的数据(如几十个元素),插入排序的性能较好,足以胜任排序任务。
  2. 部分有序的数组:如果数组大部分是有序的,插入排序会比其他复杂排序算法更有效率,因为它不需要做太多的移动。
  3. 实时数据插入:在不断插入数据并保持有序的场景下,插入排序的特性十分适合,比如插入排序在链表的排序上应用较多。

插入排序的优缺点

优点
  1. 简单易懂:算法逻辑清晰、容易实现,适合初学者掌握。
  2. 稳定性:插入排序是稳定的排序算法,相等的元素不会交换位置。
  3. 在线排序:能够实现实时插入,即在排序过程中可以逐步添加新元素,并将其插入到合适的位置。
缺点
  1. 效率较低:当数据规模增大时,插入排序的时间复杂度为 (O(n^2)),处理大数据时性能较差。
  2. 不适合逆序排序:当数据逆序或接近逆序时,插入排序需要更多的移动操作,因此效率不佳。

插入排序的实际应用

插入排序在很多实际情况下有用,比如:

  1. 少量数据排序:对于小数据量的情况(例如少于 100 个元素),插入排序的效率可以和高级排序算法媲美。
  2. 排序链表:插入排序在链表中应用广泛,因为在链表中插入元素时效率较高。
  3. 基本有序的数据:当数据大致有序,或者需要不断插入新数据并保持有序时,插入排序的性能表现良好。

插入排序的总结

插入排序是一种操作简单、适合初学者学习的排序算法。它的特点是在小规模数据或基本有序的情况下性能较好,且插入时不需要额外空间。虽然插入排序的效率不如高级排序算法,但在某些应用场景中仍然具有实际价值。

希望通过本章的学习,能够帮助大家更好地理解插入排序的基本原理、适用场景和代码实现。在掌握插入排序后,可以继续学习其他更复杂的排序算法,提升数据处理效率。

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

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

相关文章

大数据学习10之Hive高级

1.Hive高级 将大的文件按照某一列属性进行GROUP BY 就是分区&#xff0c;只是默认开窗存储&#xff1b; 分区是按行&#xff0c;如一百行数据&#xff0c;按十位上的数字分区&#xff0c;则有十个分区&#xff0c;每个分区里有十行&#xff1b; 分桶是根据某个字段哈希对桶数取…

Me-LLaMA——用于医疗领域的新型开源大规模语言模型

摘要 大规模语言模型的出现是提高病人护理质量和临床操作效率的一个重大突破。大规模语言模型拥有数百亿个参数&#xff0c;通过海量文本数据训练而成&#xff0c;能够生成类似人类的反应并执行复杂的任务。这在改进临床文档、提高诊断准确性和管理病人护理方面显示出巨大的潜…

练习LabVIEW第四十四题

学习目标&#xff1a; 计算学生三门课(语文&#xff0c;数学&#xff0c;英语)的平均分&#xff0c;并根据平均分划分成绩等级。要求输出等级A,B,C,D,E。90分以上为A&#xff0c;80&#xff5e;89为B&#xff0c;70&#xff5e;79为C&#xff0c;60&#xff5e;69为D&#xff…

【系统架构】如何演变系统架构:从单体到微服务

引言 随着企业的发展&#xff0c;网站架构必须不断演变以应对日益增长的用户流量和复杂性需求。本文将详细探讨从单体架构到微服务架构的演变过程&#xff0c;尤其关注订单和支付服务的实现方式&#xff0c;帮助您打造一个高效、可扩展的在线平台。 步骤1&#xff1a;分离应用…

Flutter鸿蒙next 实现长按录音按钮及动画特效

在 Flutter 中实现长按录音按钮并且添加动画特效&#xff0c;是一个有趣且实用的功能。本文将通过实现一个具有动画效果的长按录音按钮&#xff0c;带领你一步步了解如何使用 Flutter 完成这个任务&#xff0c;并解释每一部分的实现。 一、功能需求 我们需要一个按钮&#xf…

layui 实现 城市联动

<div class"layuimini-container"><form id"app-form" class"layui-form layuimini-form"><div class"layui-form-item"><label class"layui-form-label">标题</label><div class"la…

SpringBoot整合SpringSecurity实现密码加密解密、登录认证退出功能

文章目录 SpringBoot整合SpringSecurity实现密码加密解密、登录认证退出功能一、引言二、JWT简介与组成1、JWT简介2、JWT的组成2.1、Header&#xff08;头部&#xff09;2.2、Payload&#xff08;载荷&#xff09;2.3、Signature&#xff08;签名&#xff09; 三、Spring Secur…

重建大师7.0 | 全新倾斜高斯泼溅OPGS技术,实景三维大规模城市三维场景的更逼真化表达

在刚刚结束的“AI智算、国产信创”2024秋季新品发布会上&#xff0c;大势智慧隆重发布了重建大师7.0、重建农场信创版、低空三维AI智算平台等覆盖实景三维数据生产体系全流程、推进实景三维国产化建设与低空应用的全新系列产品。 今天&#xff0c;重点为大家介绍一下重建大师7.…

华为 Atlas500 Euler 欧拉系统操作指南

华为 Atlas500 Euler 欧拉系统操作指南 ssh root连接 找到Atlas500的IP地址&#xff0c;如&#xff1a;192.168.1.166 账号/密码&#xff1a;admin/Huawei123 root/密码&#xff1a;Huawei123456 #直接使用root ssh连接 这里受限不让直接用root连接 ssh root192.168.1.116 #…

【MySQL 保姆级教学】深层理解索引及特性(重点)--下(12)

索引&#xff08;重点&#xff09; 1. 索引的作用2. 索引操作2.1 主键索引2.1.1 主键索引的特点2.1.2 创建主键索引 2.2 唯一键索引2.2.1 唯一键索引的特点2.2.2 唯一索引的创建 2.3 普通索引2.3.1 普通索引的特点2.3.2 普通索引的创建 2.4 全文索引2.4.1 全文索引的作用2.4.2 …

SettlementfactoryController

目录 1、 SettlementfactoryController 1.1、 查询结算明细信息 1.1.1、 //SYS_RecRepairItemDetail修理项目明细表 1.1.2、 //SYS_CollageDetai领料明细表 1.1.3、 //SYS_RecOtherCostDetail其他费用明细表 1.1.4、 //SYS_InsuranceDetail保险理赔明细表 1.1.5、…

ubuntu22.04 docker-compose安装postgresql数据库

在 Ubuntu 22.04 上使用 Docker Compose 来安装和运行 PostgreSQL 数据库的过程如下&#xff1a; 1. 创建 Docker Compose 文件 在项目文件夹中创建一个 docker-compose.yml 文件&#xff0c;以配置 PostgreSQL 数据库的服务。 mkdir postgres_docker cd postgres_docker to…

只允许指定ip远程连接ssh

我们都会使用securtcrt或者xshell等软件进行远程登录&#xff0c;这样虽然会给我们带来很多便捷&#xff0c;但是同样会存在一定的风险。有很多人专门通过重复的扫描试图破解我们的linux服务器&#xff0c;从而获取免费的“肉鸡”。因此我们可以通过设置hosts.allow和hosts.den…

力扣: 144 二叉树 -- 先序遍历

二叉树 – 先序遍历 描述&#xff1a; 给你二叉树的根节点 root &#xff0c;返回它节点值的 前序 遍历。 示例&#xff1a; 先序遍历&#xff1a;根左右 何解&#xff1f; 1、递归 : 无需多言一看就懂 2、遍历法 中序查找时&#xff0c;最先出入的节点是左子树中的最左侧二叉…

maybe_unused]]编译属性

C(17)&#xff1a;[[maybe_unused]]编译属性_maybe unused-CSDN博客 避免编译器发出警告。 [[maybe_unused]] int f() //没有被使用的函数 {return 1; }int main() {[[maybe_unused]] int i 0; //没有被使用的变量return 0; }

【K8S系列】K8S 集群 CPU 爆满导致 Pod Pending 状态的分析与解决方案

在 Kubernetes 集群中&#xff0c;CPU 突然爆满可能导致 Pod 状态变为 Pending&#xff0c;影响应用的可用性。本文将深入分析其原因&#xff0c;并附上相关命令及其执行结果&#xff0c;帮助你更好地理解和解决此问题。 1. 问题描述 在 Kubernetes 集群中&#xff0c;当 CPU …

css中的样式穿透

1. >>> 操作符 <style scoped> /* 影响子组件的样式 */ .parent >>> .child {color: red; } </style>注意&#xff1a;>>> 操作符在某些预处理器&#xff08;如Sass&#xff09;中可能无法识别&#xff0c;因为它不是标准的CSS语法。 …

Linux awk命令详解-参数-选项-内置变量-内置函数-脚本(多图、多示例)

文章目录 awk基础结构说明与示例参数与内置变量常用参数内置变量其他参数内置变量 简单示例理解option简单参数NR与FNR-v ARGC ARGV参数 执行脚本if elsefor循环关联数组指定匹配pattern 使用正则指定分隔符理解pattern正则与逻辑算术 printfif else for whileBEGIN ENDnext(跳…

【Android】组件化开发入门

文章目录 引入组件是什么?为什么使用组件化开发?什么是模块化&#xff0c;组件化&#xff0c;插件化&#xff1f;常见实现 组件分层创建module 组件单独调试配置组件工程类型配置组件ApplicationId和AndroidManifest文件 引入 组件是什么? 组件&#xff08;Component&#…

计算用户订购率梧桐数据库和oracle数据库sql分析

一、背景说明 移动运营商平台提供多种类型的产品权益&#xff0c;用户可以通过订购来使用。平台需要定期统计各个产品的用户订购情况&#xff0c;以便了解各个产品的受欢迎程度。这些统计数据将用于优化产品、提升用户体验和制定市场推广策略。 二、表结构说明 梧桐数据库建…