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

插入排序:一种简单而直观的排序算法

大家好!今天我们来聊聊一个简单却非常经典的排序算法——插入排序(Insertion Sort)。在所有的排序算法中,插入排序是最直观的一个。

一、插入排序的基本思想

插入排序的核心思想是:将一个待排序的元素,插入到已排好序的部分中,使得插入后的部分依然是有序的。

具体来说,插入排序会从数组的第二个元素开始,逐步与前面的元素进行比较,并将其插入到合适的位置,直到整个数组都排序完成。

举个例子:

  1. 假设我们有一个数组 [5, 3, 8, 4, 2],我们从第二个元素开始,逐个与前面的元素进行比较。
  2. 第一次比较,我们将 35 比较,发现 3 小于 5,就将 3 插入到 5 的前面,数组变成 [3, 5, 8, 4, 2]
  3. 第二次比较,将 8 与前面的元素逐一比较,发现它已经大于 5,不需要移动。
  4. 继续这个过程,直到整个数组都变得有序。

二、插入排序的步骤

  1. 从第二个元素开始遍历,逐个元素插入到已排好序的部分。
  2. 对于每个元素,向前比较,直到找到合适的位置为止。
  3. 插入的操作可以通过移动元素的位置来完成,使得原来位置较大的元素腾出位置来插入新的元素。

三、插入排序的实现

我们通过 Java 来实现插入排序,看看这个过程是如何完成的。

public static void InsertSort(int[] arr) {//i待插入数据下标for (int i = 1; i < arr.length; i++) {//j为已排序部分最后一个元素,即待排序元素的前一个元素,使j与j+1比较,j大交换,j小结束for (int j = i - 1; j >= 0; j--) {if (arr[j] > arr[j + 1]) {int temp = arr[j];arr[j] = arr[j + 1];arr[j + 1] = temp;} else{break;}}}}

四、插入排序的时间复杂度

插入排序的时间复杂度主要取决于待排序数据的顺序。

  • 最优情况:当数组已经是有序的时,内层循环不会执行任何移动操作,因此时间复杂度是 O(n),其中 n 是数组的长度。

  • 最坏情况:当数组是逆序时,每次插入都需要将元素移动到数组的前面,这时内层循环会执行 i 次移动操作。因此时间复杂度是 O(n²)

  • 平均情况:假设元素是随机排列的,平均情况下,时间复杂度也为 O(n²)

五、插入排序的优缺点

优点:
  1. 简单直观:插入排序的实现非常简单,而且非常适合小规模数据的排序。
  2. 稳定性:插入排序是稳定的排序算法,即相等的元素不会交换位置。
  3. 适用于部分有序的数组:当数组已经接近有序时,插入排序会表现得非常高效。
缺点:
  1. 时间复杂度高:在数据规模较大的时候,插入排序的效率较低,特别是在最坏情况下,时间复杂度达到 O(n²)
  2. 不适合大规模数据:对于大数据量的排序,插入排序不是最优选择。其他更高效的排序算法(如快速排序、归并排序)通常会更适用。

六、插入排序的应用场景

尽管插入排序在大规模数据中效率较低,但在一些特殊场景下,它依然非常有用:

  1. 小规模数据排序:在数据量较小的情况下,插入排序非常高效且简单。
  2. 部分有序的数组:如果数据已经部分有序,插入排序可以大大减少排序的工作量。
  3. 在线算法:插入排序是一种在线算法,也就是说它可以逐步地接收新的数据并进行排序。例如在实时排序数据流时,可以使用插入排序。

相关文章:

插入排序:一种简单而直观的排序算法

大家好&#xff01;今天我们来聊聊一个简单却非常经典的排序算法——插入排序&#xff08;Insertion Sort&#xff09;。在所有的排序算法中&#xff0c;插入排序是最直观的一个。 一、插入排序的基本思想 插入排序的核心思想是&#xff1a;将一个待排序的元素&#xff0c;插…...

2.24力扣每日一题--设计有序流

1656. 设计有序流 - 力扣&#xff08;LeetCode&#xff09; &#xff08;设计一个可以存储n个字符串的数据结构&#xff0c;其中满足存在一个”指针“&#xff0c;用以展示当下是否还存在空间存储&#xff0c;每个字符串有自己ID需要存储&#xff09; 数据结构&#xff1a; 字…...

本地Oracle数据库复制数据到Apache Hive的Linux服务器集群的分步流程

我们已经有安装Apache Hive的Linux服务器集群&#xff0c;它可以连接到一个Oracle RDS数据库&#xff0c;需要在该Linux服务器上安装配置sqoop&#xff0c;然后将Oracle RDS数据库中所有的表数据复制到Hive。 为了将本地Oracle数据库中的所有表数据复制到Apache Hive Linux服务…...

【R语言】ggplot2绘图常用操作

目录 坐标轴以及标签的相关主题 图例调整 字体类型设置 颜色相关 ggplot2如何添加带箭头的坐标轴&#xff1f; 标题相关主题调整 修改点图中点的大小 如何使得点的大小根据变量取值的大小来改变&#xff1f; 柱状图和条形图 坐标轴以及标签的相关主题 theme( # 增大X…...

正态分布的奇妙性质:为什么奇数阶中心矩(odd central moments)为零?

正态分布的奇妙性质&#xff1a;为什么奇数阶矩为零&#xff1f; 正态分布&#xff08;Normal Distribution&#xff09;是统计学中最常见的分布之一&#xff0c;它的钟形曲线几乎无处不在&#xff0c;从身高体重到测量误差&#xff0c;都能看到它的影子。除了均值和方差这两个…...

架构——Nginx功能、职责、原理、配置示例、应用场景

以下是关于 Nginx 的功能、职责、原理、配置示例、应用场景及其高性能原因的详细说明&#xff1a; 一、Nginx 的核心功能 1. 静态资源服务 功能&#xff1a;直接返回静态文件&#xff08;如 HTML、CSS、JS、图片、视频等&#xff09;。配置示例&#xff1a;server {listen 80…...

涉密载体管控系统革新:RFID技术引领,信息安全新境界

行业背景 文件载体管控系统DW-S402是用于对各种SM载体进行有效管理的智能柜&#xff08;智能管理系统&#xff09;&#xff0c;实现对载体的智能化、规范化、标准化管理&#xff0c;广泛应用于保密、机要单位以及企事业单位等有载体保管需求的行业。 随着信息化技术发展&…...

基于 SpringBoot 的 “电影交流平台小程序” 系统的设计与实现

大家好&#xff0c;今天要和大家聊的是一款基于 SpringBoot 的 “电影交流平台小程序” 系统的设计与实现。项目源码以及部署相关事宜请联系我&#xff0c;文末附上联系方式。 项目简介 基于 SpringBoot 的 “电影交流平台小程序” 系统设计与实现的主要使用者分为 管理员 和…...

【Rust中级教程】2.9. API设计原则之显然性(obvious) :文档与类型系统、语义化类型、使用“零大小”类型

喜欢的话别忘了点赞、收藏加关注哦&#xff08;加关注即可阅读全文&#xff09;&#xff0c;对接下来的教程有兴趣的可以关注专栏。谢谢喵&#xff01;(&#xff65;ω&#xff65;) 2.9.1. 文档与类型系统 用户可能不会完全理解API的所有规则和限制。所以你写的API应该让你…...

git branch

文章目录 1.简介2.格式3.选项4.示例参考文献 1.简介 git branch 用于管理分支&#xff0c;包括查看、创建、删除、重命名和关联。 git branch 是 Git 版本控制系统中用于管理分支的命令。分支是 Git 的核心功能之一&#xff0c;允许开发者在同一个代码库中并行开发不同的功能…...

【网络编程】广播和组播

数据包发送方式只有一个接受方&#xff0c;称为单播。如果同时发给局域网中的所有主机&#xff0c;称为广播。只有用户数据报(使用UDP协议)套接字才能广播&#xff1a; 广播地址以192.168.1.0 (255.255.255.0) 网段为例&#xff0c;最大的主机地址192.168.1.255代表该网段的广…...

运维Crontab面试题及参考答案

Crontab 文件的六个域分别是什么&#xff1f;顺序如何&#xff1f; Crontab 文件用于设置定时执行任务&#xff0c;其六个域及顺序从左到右依次为&#xff1a;分钟&#xff08;Minute&#xff09;、小时&#xff08;Hour&#xff09;、日期&#xff08;Day of month&#xff09…...

Lecture 1 - AI Systems (Overview)

一、Machine Learning Approach标准机器学习流程 • Train ML algorithm&#xff08;训练机器学习算法&#xff09;&#xff1a;基于收集的数据训练机器学习模型。 二、Machine Learning for Adaptation&#xff08;适应性机器学习&#xff09; 加入了数据更新和自动化的部分…...

Ansible 学习笔记

这里写自定义目录标题 基本架构文件结构安装查看版本 Ansible 配置相关文件主机清单写法 基本架构 Ansible 是基于Python实现的&#xff0c;默认使用22端口&#xff0c; 文件结构 安装 查看用什么语言写的用一下命令 查看版本 Ansible 配置相关文件 主机清单写法...

设计模式-结构型-代理模式

1. 代理模式概述 代理模式&#xff08;Proxy Pattern&#xff09; 是一种结构型设计模式&#xff0c;它允许通过代理对象来控制对目标对象的访问。代理模式主要用于以下场景&#xff1a; 控制对象访问&#xff1a;限制某些对象的访问权限&#xff0c;例如权限控制。 延迟实例…...

FCC CE SRRC MIC是什么意思?

1.FCC CE SRRC MIC是什么意思&#xff1f; 2.4000 GHz 至 2.4835 GHz&#xff1a;<33 dBm&#xff08;FCC&#xff09;&#xff0c;<20 dBm&#xff08;CE/SRRC/MIC&#xff09; 5.150 GHz 至 5.250 GHz&#xff08;CE&#xff1a;5.170 GHz 至 5.250 GHz&#xff09;&a…...

springboot005学生心理咨询评估系统(源码+数据库+文档)

源码地址&#xff1a;学生心理咨询评估系统 文章目录 1.项目简介2.部分数据库结构与测试用例3.系统功能结构4.包含的文件列表&#xff08;含论文&#xff09;后台运行截图 1.项目简介 ​ 使用旧方法对学生心理咨询评估信息进行系统化管理已经不再让人们信赖了&#xff0c;把现…...

Apache Doris:一款高性能的实时数据仓库

Apache Doris 是一款基于 MPP 架构的高性能、实时分析型数据库。它以高效、简单和统一的特性著称&#xff0c;能够在亚秒级的时间内返回海量数据的查询结果。Doris 既能支持高并发的点查询场景&#xff0c;也能支持高吞吐的复杂分析场景。 Apache Doris 最初是百度广告报表业务…...

使用Vue-Flow创建一个流程图可视化节点坐标查询器

在开发中遇到这样一个需求&#xff0c;需要后端返回数据前端网页生成流程图&#xff0c;由于流程图使用了Vue-Flow&#xff0c;所以需要坐标来辅助后端生成数据。 首先引入方法并定义添加节点数据 const { updateEdge, addEdges, addNodes} useVueFlow() const add_nodes …...

面试基础--Java 集合框架详解

Java 集合框架详解&#xff1a;从 ArrayList 到 HashMap 的底层原理 引言 在 Java 开发中&#xff0c;集合框架&#xff08;Collection Framework&#xff09;是处理数据存储和操作的核心工具。无论是日常开发还是大厂面试&#xff0c;对集合框架的理解都是考察的重点之一。本…...

轻量级日志管理平台Grafana Loki

文章目录 轻量级日志管理平台Grafana Loki背景什么是Loki为什么使用 Grafana Loki&#xff1f;架构Log Storage Grafana部署使用基于 Docker Compose 安装 LokiMinIO K8s集群部署Loki采集Helm 部署方式和案例 参考 轻量级日志管理平台Grafana Loki 背景 在微服务以及云原生时…...

回文串

长度为偶数的串&#xff0c;重排连续字串变成回文串。 Problem - D - Codeforces 代码&#xff1a; #include <bits/stdc.h> #define fi first #define se second using namespace std; typedef long long LL; typedef pair<int,int> PII; typedef pair<LL,L…...

《跟李沐学 AI》AlexNet论文逐段精读学习心得 | PyTorch 深度学习实战

前一篇文章&#xff0c;使用 AlexNet 实现图片分类 | PyTorch 深度学习实战 本系列文章 GitHub Repo: https://github.com/hailiang-wang/pytorch-get-started 本篇文章内容来自于学习 9年后重读深度学习奠基作之一&#xff1a;AlexNet【下】【论文精读】】的心得。 《跟李沐…...

【电机控制器】FU6832S——持续更新

【电机控制器】FU6832S——持续更新 文章目录 [TOC](文章目录) 前言一、ADC二、UART三、PWM四、参考资料总结 前言 使用工具&#xff1a; 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面案例可供参考 一、ADC 二、UART 三、PWM 四、参考资料 总结 本文仅仅简…...

Flutter屏幕适配终极方案:flutter_screenutil深度解析

在跨平台应用开发中&#xff0c;屏幕适配始终是开发者面临的核心挑战。Flutter虽然自带响应式布局体系&#xff0c;但面对复杂的设计稿标注时&#xff0c;手动计算比例效率低下。今天我们将深度解析目前Flutter社区最受欢迎的屏幕适配方案——flutter_screenutil&#xff0c;手…...

计算机视觉算法实战——产品分拣(主页有源码)

✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连 ✨ ✨个人主页欢迎您的访问 ✨期待您的三连✨ ​ 1. 领域简介✨✨ 产品分拣是工业自动化和物流领域的核心技术&#xff0c;旨在通过机器视觉系统对传送带上的物品进行快速识别、定位和分类&a…...

可视化报表

根据你的需求&#xff0c;以下是一些可以实现报表可视化的开源项目&#xff0c;这些项目提供了类似阿里巴巴 FBI 报表的功能&#xff0c;支持数据可视化、报表设计、仪表盘和大屏展示等功能&#xff1a; 1. DataEase DataEase 是一个开源的 BI 工具&#xff0c;帮助用户快速分…...

基于模块联邦的微前端架构:重构大型前端应用的模块化边界

引言&#xff1a;企业级前端的模块化困境 字节跳动广告系统采用Webpack 5模块联邦后&#xff0c;主应用构建时间从14分钟降至38秒&#xff0c;微应用独立发布频率提升至每天50次。在动态加载机制下&#xff0c;首屏资源加载体积减少79%&#xff0c;跨团队组件复用率达到92%。其…...

Android之图片保存相册及分享图片

文章目录 前言一、效果图二、实现步骤1.引入依赖库2.二维码生成3.布局转图片保存或者分享 总结 前言 其实现在很多分享都是我们自定义的&#xff0c;更多的是在界面加了很多东西&#xff0c;然后把整个界面转成图片保存相册和分享&#xff0c;而且现在分享都不需要第三方&…...

Linux放行端口

8080这个端口测试看telnet是不通的&#xff0c;您服务器内是否有对应的业务监听了这个端口呢&#xff1f;您到服务器内执行下&#xff1a; netstat -nltp |grep 8080 同时服务器内执行下&#xff1a; systemctl status firewalld iptables -nL 截图反馈下&#xff0c;我看下防火…...