C语言插入排序及其优化

插入排序算法详解

插入排序是一种简单直观的排序算法。它通过构建有序序列,将未排序部分的元素插入到已排序部分的正确位置,直到所有元素排序完成。下面是插入排序的关键点及其实现细节。


算法思想

  1. 从第二个元素(下标为 1)开始,假定左侧的子数组已排序。
  2. 将当前元素与已排序部分逐一比较,找到插入点。
  3. 将插入点后的元素依次后移,为当前元素腾出位置。
  4. 重复上述过程,直至所有元素排序完成。

直接插入法排序

复制代码
void insert_sort(int array[], int size) {
    for (int i = 1; i < size; i++) {
        int temp = array[i]; // 当前待插入的元素
        int j = i - 1;

        // 查找插入位置
        while (j >= 0 && temp < array[j]) {
            array[j + 1] = array[j]; // 元素后移
            j--;
        }
        array[j + 1] = temp; // 插入元素
    }
}

优化方法

插入排序的主要时间消耗来源于:

  1. 查找插入位置的比较操作。
  2. 元素后移的赋值操作。

可以通过以下方法进行优化:

二分插入法排序

复制代码
#include <stdio.h>

void insert_sort(int array[], int size) {
    for (int i = 1; i < size; i++) {
        int temp = array[i];
        int left = 0, right = i - 1;

        // 二分查找插入位置
        while (left <= right) {
            int mid = (left + right) / 2;
            if (array[mid] > temp)
                right = mid - 1;
            else
                left = mid + 1;
        }

        // 将大于 temp 的元素右移
        for (int j = i - 1; j >= left; j--) {
            array[j + 1] = array[j];
        }
        array[left] = temp; // 插入到正确位置
    }
}

时间复杂度分析

操作 最好情况(数组已排序) 最坏情况(数组逆序) 平均情况
比较次数 O(n)O(n)O(n) O(n2)O(n^2)O(n2) O(n2)O(n^2)O(n2)
移动次数 O(n)O(n)O(n) O(n2)O(n^2)O(n2) O(n2)O(n^2)O(n2)

尽管插入排序在最坏情况下的复杂度是 O(n2)O(n^2)O(n2),但在以下情况下表现良好:

  1. 数据接近有序时,比较和移动次数大幅减少。
  2. 数据量较小时,插入排序的简单性使其执行速度不逊于复杂的排序算法。
相关推荐
无敌最俊朗@10 小时前
力扣hot100-206反转链表
算法·leetcode·链表
Kuo-Teng10 小时前
LeetCode 279: Perfect Squares
java·数据结构·算法·leetcode·职场和发展
王哈哈^_^10 小时前
YOLO11实例分割训练任务——从构建数据集到训练的完整教程
人工智能·深度学习·算法·yolo·目标检测·机器学习·计算机视觉
檐下翻书17311 小时前
从入门到精通:流程图制作学习路径规划
论文阅读·人工智能·学习·算法·流程图·论文笔记
CoderYanger11 小时前
B.双指针——3194. 最小元素和最大元素的最小平均值
java·开发语言·数据结构·算法·leetcode·职场和发展·1024程序员节
小曹要微笑12 小时前
STM32各系列时钟树详解
c语言·stm32·单片机·嵌入式硬件·算法
inputA13 小时前
【LwIP源码学习8】netbuf源码分析
android·c语言·笔记·嵌入式硬件·学习
前进的李工13 小时前
LeetCode hot100:094 二叉树的中序遍历:从递归到迭代的完整指南
python·算法·leetcode·链表·二叉树
麦麦大数据14 小时前
F049 知识图谱双算法推荐在线学习系统vue+flask+neo4j之BS架构开题论文全源码
学习·算法·知识图谱·推荐算法·开题报告·学习系统·计算机毕业设计展示
兩尛14 小时前
215. 数组中的第K个最大元素
数据结构·算法·排序算法