python 插入排序(Insertion Sort)
插入排序(Insertion Sort)
插入排序是一种简单的排序算法。它的基本思想是:将数组分为已排序部分和未排序部分,然后逐个将未排序部分的元素插入到已排序部分的正确位置。插入排序类似于整理扑克牌的过程。
插入排序的步骤:
- 初始化:将第一个元素视为已排序部分。
- 插入元素:从未排序部分取出一个元素,将其插入到已排序部分的正确位置。
- 重复过程:重复上述步骤,直到所有元素都被排序。
时间复杂度:
- 最坏情况:O(n²) —— 当数组是逆序的时候。
- 最好情况:O(n) —— 当数组已经有序的时候。
- 平均情况:O(n²)
空间复杂度:
- O(1) —— 插入排序是一种原地排序算法,不需要额外的存储空间。
Python 实现
def insertion_sort(arr):n = len(arr)for i in range(1, n):key = arr[i] # 当前需要插入的元素j = i - 1# 将比 key 大的元素向后移动while j >= 0 and arr[j] > key:arr[j + 1] = arr[j]j -= 1# 将 key 插入到正确位置arr[j + 1] = keyreturn arr# 示例使用
arr = [12, 11, 13, 5, 6]
sorted_arr = insertion_sort(arr)
print("排序后的数组:", sorted_arr)
输出结果
排序后的数组: [5, 6, 11, 12, 13]
插入排序的详细过程
以数组 [12, 11, 13, 5, 6] 为例:
-
第一轮:
- 已排序部分:
[12] - 未排序部分:
[11, 13, 5, 6] - 将
11插入到已排序部分,数组变为[11, 12, 13, 5, 6]。
- 已排序部分:
-
第二轮:
- 已排序部分:
[11, 12] - 未排序部分:
[13, 5, 6] - 将
13插入到已排序部分,数组变为[11, 12, 13, 5, 6]。
- 已排序部分:
-
第三轮:
- 已排序部分:
[11, 12, 13] - 未排序部分:
[5, 6] - 将
5插入到已排序部分,数组变为[5, 11, 12, 13, 6]。
- 已排序部分:
-
第四轮:
- 已排序部分:
[5, 11, 12, 13] - 未排序部分:
[6] - 将
6插入到已排序部分,数组变为[5, 6, 11, 12, 13]。
- 已排序部分:
-
排序完成。
插入排序的优缺点
优点:
- 实现简单,易于理解。
- 对于小规模数据或基本有序的数据,效率较高。
- 是稳定的排序算法(相同元素的相对位置不变)。
缺点:
- 时间复杂度较高,不适合处理大规模数据。
- 对于逆序数据,性能较差。
插入排序的适用场景
- 数据规模较小。
- 数据基本有序。
- 需要稳定排序的场景。
相关文章:
python 插入排序(Insertion Sort)
插入排序(Insertion Sort) 插入排序是一种简单的排序算法。它的基本思想是:将数组分为已排序部分和未排序部分,然后逐个将未排序部分的元素插入到已排序部分的正确位置。插入排序类似于整理扑克牌的过程。 插入排序的步骤&#…...
电子应用设计方案81:智能AI冲奶瓶系统设计
智能 AI 冲奶瓶系统设计 一、引言 智能 AI 冲奶瓶系统旨在为父母或照顾者提供便捷、准确和卫生的冲奶服务,特别是在夜间或忙碌时,减轻负担并确保婴儿获得适宜的营养。 二、系统概述 1. 系统目标 - 精确调配奶粉和水的比例,满足不同年龄段婴…...
JAVA高并发总结
JAVA高并发编程总结 在现代应用中,高并发编程是非常重要的一部分,尤其是在分布式系统、微服务架构、实时数据处理等领域。Java 提供了丰富的并发工具和技术,帮助开发者在多线程和高并发的场景下提高应用的性能和稳定性。以下是 Java 高并发编…...
【AIGC】使用Java实现Azure语音服务批量转录功能:完整指南
文章目录 引言技术背景环境准备详细实现1. 基础架构设计2. 实现文件上传功能3. 提交转录任务crul4. 获取转录结果 使用示例结果示例最佳实践与注意事项总结 引言 在当今数字化时代,将音频内容转换为文本的需求越来越普遍。无论是会议记录、视频字幕生成,…...
arcgis模版空库怎么用(一)
这里以某个项目的数据为例: 可以看到,属性表中全部只有列标题,无数据内容 可能有些人会认为空库是用来往里面加入信息的,其实不是,正确的用法如下: 一、下图是我演示用的数据,我们可以看到其中…...
【电机控制】基于STC8H1K28的六步换向——方波驱动(软件篇)
【电机控制】基于STC8H1K28的六步换向——方波驱动(软件篇) 文章目录 [TOC](文章目录) 前言一、main.c二、GPIO.c三、PWMA.c四、ADC.c五、CMP.c六、Timer.c七、PMSM.c八、参考资料总结 前言 【电机控制】STC8H无感方波驱动—反电动势过零检测六步换向法 …...
小程序配置文件 —— 13 全局配置 - window配置
全局配置 - window配置 这里讲解根目录 app.json 中的 window 字段,window 字段用于设置小程序的状态栏、导航条、标题、窗口背景色; 状态栏:顶部位置,有网络信号、时间信息、电池信息等;导航条:有一个当…...
全球域名市场科普之域名交易平台介绍——Sedo与Afternic
关于Dynadot Dynadot是通过ICANN认证的域名注册商,自2002年成立以来,服务于全球108个国家和地区的客户,为数以万计的客户提供简洁,优惠,安全的域名注册以及管理服务。 Dynadot平台操作教程索引(包括域名邮…...
leetcode108:将有序数组转化为二叉搜索树
给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。 示例 1: 输入:nums [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视为正确…...
截图技术方案
安卓截屏技术附带悬浮窗自动存储功能_安卓截图浮窗-CSDN博客 https://chat.baidu.com/search?dyTabStrMCwxMiwzLDEsMiwxMyw3LDYsNSw5&pdcsaitab&setypecsaitab&extParamsJson%7B%22apagelid%22%3A%2210990774271994514433%22%2C%22enter_type%22%3A%22a_ai_index%…...
程序员测试日常小工具
作为一名程序员,或者测试人员,日常工作最常用的工具有哪些,截图,截图漂浮,翻译,日期处理,api调用..., 当你拿到一串报文后,想要json转换时,是不是要打…...
Kubernetes: NetworkPolicy 的实践应用
一、Network Policy 是什么,在云原生领域有和作用 Network Policy 是 Kubernetes 官方提出来的一种网络策略的规范,用户通过编写符合对应规范的规则来控制 k8s 集群内 L3 和 L4 层的网络流量。 NetworkPolicy 主要的功能就是实现在云原生领域的容器网络管控它给用…...
HTML5滑块(Slider)
HTML5 的滑块(Slider)控件允许用户通过拖动滑块来选择数值。以下是如何实现一个简单的滑块组件的详细说明。 HTML5 滑块组件 1. 基本结构 使用 <input type"range"> 元素可以创建一个滑块。下面是基本实现的代码示例: <…...
数据结构与算法之动态规划: LeetCode 72. 编辑距离 (Ts版)
编辑距离 https://leetcode.cn/problems/edit-distance/description/ 描述 给你两个单词 word1 和 word2, 请返回将 word1 转换成 word2 所使用的最少操作数你可以对一个单词进行如下三种操作: 插入一个字符删除一个字符替换一个字符 示例 1 输入&…...
洪水灾害多智能体分布式模拟示例代码
1. 环境定义:支持灾害动态、地理数据和分布式架构 import numpy as np import random import matplotlib.pyplot as plt# 新疆主要城市及邻接关系 XINJIANG_CITIES {Urumqi: [Changji, Shihezi],Changji: [Urumqi, Shihezi, Turpan],Shihezi: [Urumqi, Changji, K…...
【前端】Node.js使用教程
目录 一、?Node.js开发环境和编译 1.1 安装Node.js 1.2 创建一个Node.js项目 1.3 编写Node.js程序 1.4 运行Node.js程序 1.5 使用Node.js模块 二、高级的Node.js编程概念和示例 2.1 异步编程 2.2 错误处理 2.3 网络请求 2.4 构建Web服务器 2.5 数据库交互 三、No…...
django33全栈班2025年004 录入数据
前言 通过前面的学习, 我们已经算是Python基本入门了. 如果你能熟练的掌握的话, 至少让你换台电脑, 在新电脑上搭建Python的开发环境肯定是没问题的. 我们呢也学习了第一行Python代码, 但是我们不知道这行代码是什么意思, 为什么能够运行, 怎么就能输出到控制台呢? 还有, …...
小白投资理财 - 看懂 EPS 每股收益
小白投资理财 - 看懂 EPS 每股收益 什么是 EPSEPS 缺陷EPS 优点EPS 跟自己比EPS 跟别人比 总结 投资一家公司就要选择会赚钱的公司,我们最为关心的莫过于公司的盈利能力,只有会下蛋的鸡才是好鸡,买股票为的就是获得利润。想成为一位成功的投资…...
Pandas-apply自定义函数
文章目录 一. Series的apply方法1. 一个元素一个元素的传入2. apply传入一个参数函数2.apply传入多个参数函数 二. DataFrame的apply方法1. axis参数指定按行/ 按列(默认)传入数据2. apply使用 三. apply 使用案例1. 栗子12. 栗子2-列3. 栗子3-行 四. 向量化函数1. 使用np.vect…...
github 项目分享
今天和大家分享一些github上面搜到关于卫星遥感和水环境相关的项目。 一、WaterDetect 使用端到端算法去识别水体范围的算法,针对哨兵2卫星遥感数据可用。 项目地址: https://github.com/cordmaur/WaterDetect 二、DeepWaterMap 深度卷积神经网络去…...
丹青幻境完整使用流程:从铺陈画纸到揭榜留存,一步不漏
丹青幻境完整使用流程:从铺陈画纸到揭榜留存,一步不漏 1. 走进丹青幻境 "见微知著,凝光成影。执笔入画,神游万象。"丹青幻境是一款基于Z-Image架构与Cosplay LoRA技术打造的数字艺术创作工具。它将现代AI算力与传统水…...
实测GLM-TTS:方言克隆效果惊艳,情感表达自然流畅
实测GLM-TTS:方言克隆效果惊艳,情感表达自然流畅 1. 语音克隆技术的新突破 近年来,语音合成技术取得了显著进展,但传统方案在方言支持和情感表达方面仍存在明显短板。GLM-TTS作为智谱AI开源的文本转语音模型,通过创新…...
SecGPT-14B模型微调:让OpenClaw更懂你的安全需求
SecGPT-14B模型微调:让OpenClaw更懂你的安全需求 1. 为什么需要微调安全模型 去年我在使用OpenClaw自动化处理公司安全日志时,发现一个尴尬现象:当要求AI分析潜在漏洞时,它总是给出一些"教科书式"的通用建议ÿ…...
AI绘画不求人:Neeshck-Z-lmage_LYX_v2本地化部署与使用指南
AI绘画不求人:Neeshck-Z-lmage_LYX_v2本地化部署与使用指南 1. 工具概览:你的私人AI画师 想象一下,你有一个随时待命的数字画家,只需要输入文字描述,就能在几分钟内为你创作出精美的画作。Neeshck-Z-lmage_LYX_v2正是…...
多模态扩展:OpenClaw调用Qwen3-32B实现截图内容分析
多模态扩展:OpenClaw调用Qwen3-32B实现截图内容分析 1. 为什么需要截图内容分析能力 去年我在整理技术文档时,经常遇到这样的场景:某个软件界面的配置项需要记录下来,但手动抄写既费时又容易出错。当时我尝试过各种OCR工具&…...
安全日报生成:OpenClaw+SecGPT-14B自动汇总24小时安全事件
安全日报生成:OpenClawSecGPT-14B自动汇总24小时安全事件 1. 为什么需要自动化安全日报 作为一名安全工程师,每天早晨打开邮箱看到堆积如山的告警日志时,那种头皮发麻的感觉我至今难忘。传统的安全运营流程中,分析师需要手动筛选…...
快速部署Qwen3-ASR-1.7B:实现多语言语音转文字功能实战教程
快速部署Qwen3-ASR-1.7B:实现多语言语音转文字功能实战教程 1. 引言:语音识别技术的新选择 语音转文字技术正在改变我们处理音频内容的方式。Qwen3-ASR-1.7B作为阿里通义千问推出的中等规模语音识别模型,凭借17亿参数的平衡设计,…...
Qwen3-0.6B-FP8效果展示:中文方言理解(粤语/川普)与转写准确性测试
Qwen3-0.6B-FP8效果展示:中文方言理解(粤语/川普)与转写准确性测试 1. 引言:当大模型遇上“家乡话” 想象一下,你对着一个AI助手说:“今朝天气几好,不如去饮茶啦?” 或者 “你娃儿…...
48V锂电池双向DCDC充放电MATLAB仿真研究
48V锂电池双向DCDC充放电MATLAB仿真上个月帮工作室新入职的阿凯改48V露营双向小储能的模型——对,仿真模型,毕竟48V、2kW半的IGBT炸一套顶他半个月咖啡钱。刚拿到手的时候阿凯拍胸脯说“buck-boost双向嘛,MATLAB/Simulink现成的库拉几个就行”…...
从零到盈利:Unity小游戏如何通过穿山甲广告实现收入最大化
从零到盈利:Unity小游戏如何通过穿山甲广告实现收入最大化 在移动游戏市场,广告变现已成为中小开发者最可靠的收入来源之一。根据行业数据显示,超休闲游戏开发者平均70%的收入来自广告展示,而穿山甲作为国内领先的广告平台&#x…...
