插入算法介绍(c基础)

一、插入算法概述

  1. 定义
    • 插入算法是一种常见的排序算法,它的基本思想是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。
  2. 适用场景
    • 插入算法适用于数据量较小,且数据基本有序的情况。它在这种场景下能够高效地对数据进行排序。

二、直接插入排序

  1. 算法原理
    • 假设数组arr,初始时,将arr[0]视为已排序序列,arr[1]arr[n - 1]视为未排序序列(n为数组长度)。
    • i = 1开始,将arr[i]与已排序序列中的元素从后向前比较。如果arr[i]小于已排序序列中的元素,则将该元素向后移动一位,直到找到合适的位置将arr[i]插入。
    • 重复这个过程,直到所有元素都插入到已排序序列中。
  2. C 语言示例代码

展开过程

  • 这里key是当前要插入的元素,while循环用于在已排序序列中找到key的合适插入位置。
  1. 时间复杂度

    • 最好情况:当数组已经有序时,每次只需要比较一次就能确定插入位置,时间复杂度为。
    • 最坏情况:当数组逆序时,每次插入都需要移动大量元素,时间复杂度为。
    • 平均情况:时间复杂度为。
  2. 空间复杂度

    • 插入排序只需要常数级的额外空间,空间复杂度为。

三、希尔排序(改进的插入排序)

  1. 算法原理
    • 希尔排序是对直接插入排序的改进。它的基本思想是先将整个待排序的记录序列分割成为若干子序列分别进行直接插入排序,待整个序列中的记录 "基本有序" 时,再对全体记录进行一次直接插入排序。
    • 子序列的构成不是简单地逐段分割,而是将相隔某个 "增量" 的记录组成子序列。
  2. C 语言示例代码

展开过程

  • 这里gap是增量,通过不断缩小增量来对数组进行排序。
  1. 时间复杂度
    • 希尔排序的时间复杂度与增量序列的选择有关,平均时间复杂度在左右。
  2. 空间复杂度
    • 空间复杂度为。

插入算法是一种简单而实用的排序算法,在特定场景下能够发挥很好的排序效果,并且通过改进(如希尔排序)还能在一定程度上提高排序效率

相关推荐
CoovallyAIHub13 分钟前
【工业检测新思路】抛弃边界框!基于头部关键点的工地安全帽检测
深度学习·算法·计算机视觉
Studying 开龙wu35 分钟前
机器学习监督学习sklearn实战三:八种算法对印第安人糖尿病预测数据进行分类和比较
深度学习·算法·机器学习
xtmatao41 分钟前
WIN11+VSCODE搭建的c/c++环境调试报错解决
c语言·c++·vscode
Coovally AI模型快速验证1 小时前
基于YOLO-NAS-Pose的无人机象群姿态估计:群体行为分析的突破
人工智能·神经网络·算法·yolo·目标检测·无人机·cocos2d
鑫鑫向栄1 小时前
[蓝桥杯]填字母游戏
数据结构·c++·算法·蓝桥杯·深度优先
电鱼智能的电小鱼1 小时前
无人机巡检智能边缘计算终端技术方案‌‌——基于EFISH-SCB-RK3588工控机/SAIL-RK3588核心板的国产化替代方案‌
网络·人工智能·嵌入式硬件·算法·机器人·无人机·边缘计算
筏.k1 小时前
C++ 新特性详解:Lambda 表达式全解析(含实战案例)
c语言·开发语言·c++
量子炒饭大师2 小时前
项目实战——C语言扫雷游戏
c语言·开发语言·游戏
纪元A梦3 小时前
分布式拜占庭容错算法——实现工作量证明(PoW)算法详解
java·分布式·算法
_李白_3 小时前
分布式互斥算法
分布式·算法