查找与排序-插入排序

1.直接插入排序的基本思想

假设n个数据元素关键字存储在静态数组a中,则直接插入排序的基本思想可做如下描述:

(1)初始有序子序列由一个元素a0 组成;

(2)从a1开始,对于序列中每个元素ai,利用顺序查找在有序子序列中找到其合适位置,然后将后面的元素向后移动,并将ai插入。

(3)重复上述步骤,直到整个序列有序,算法结束。

2.直接插入排序举例

例:设待排元素序列为{56,25,70,99,82,10,15,56},请给出按直接插入排序算法进行排序的过程。

3.直接插入排序算法代码

复制代码
def insertion_sort(self):
    for i in range(1, len(self.data)):  # 依次将i号记录插入在表中0至i-1部分的有序序列中
       	 if self.data[i] < self.data[i - 1]:
           temp = self.data[i]
           j = i - 1
           while j >= 0 and self.data[j] > temp:  # 依次与之前的每个记录关键字比较
               self.data[j + 1] = self.data[j]  # 如前面记录更大则后移
	           j -= 1  # j往前移动
                self.data[j + 1] = temp  # temp记录放在j+1位置

4.直接插入排序算法分析

(1)空间复杂度:只需要一个记录大小的辅助空间来临时存放待插入记录,空间复杂度O(1)。 (2)时间复杂度:最好情况下,如果数组本身是从小到大排列的,每趟操作只需要1次比较,总比较次数为n-1,不需要移动数据元素。最坏情况下,如果数组是从大到小排列的,那么关键字的总比较次数为n(n-1)/2,移动的次数为n(n-1)/2,因此时间复杂度为O(n2) 。

(3)该算法是稳定算法。

相关推荐
xqqxqxxq27 分钟前
树结构技术学习笔记
数据结构·笔记·学习
十月的皮皮1 小时前
C语言学习笔记202606008- 三角形判断(3种方法)
c语言·笔记·学习
XGeFei1 小时前
【Fastapi学习笔记(6)】—— Fastapi文件上传、请求头自动转换
笔记·学习·fastapi
嘶哈哈哈1 小时前
嘉立创 EDA 入门实操笔记:从原理图到 PCB 布线、差分对、覆铜与 DRC 检查
开发语言·笔记·php
一口吃俩胖子2 小时前
【脉宽调制DCDC功率变换学习笔记024】频域性能
笔记·学习
吃着火锅x唱着歌2 小时前
深度探索C++对象模型 学习笔记 第五章 构造、解构、拷贝语意学(2)
c++·笔记·学习
Upsy-Daisy2 小时前
Hermes Agent 学习笔记 04:工具调用系统,让 Agent 从“会说”变成“会做”
java·笔记·学习
John_ToDebug2 小时前
在 Windows 上搭建 Chromium 148 内核编译环境:一份实战笔记
chrome·经验分享·笔记
快乐得小萝卜2 小时前
论文:π0.5
笔记·深度学习
sbjdhjd2 小时前
面试题完结 | 投票题 + 到岗时间 + 压力缓解
经验分享·笔记·面试·职场和发展·开源·求职招聘·印象笔记