【C语言】深入解析插入排序算法

一、基本思想

插入排序(Insertion Sort)是一种简单直观的排序算法。其基本思想是将无序序列逐个插入到有序序列中,从而得到一个新的有序序列。插入排序类似于我们日常生活中整理扑克牌的过程,每次将一张牌插入到已经有序的牌中,最终得到一个有序的牌序列。

二、算法步骤

  1. 从第一个元素开始,该元素可以认为已经被排序;
  2. 取出下一个元素,在已经排序的元素序列中从后向前扫描;
  3. 如果该元素(已排序)大于新元素,将该元素移到下一位置;
  4. 重复步骤3,直到找到已排序的元素小于或者等于新元素的位置;
  5. 将新元素插入到该位置后;
  6. 重复步骤2~5。

三、性能分析

插入排序的时间复杂度为O( n 2 n^2 n2),空间复杂度为O(1)。在最坏情况下,插入排序需要比较次数为 n ∗ ( n − 1 ) / 2 n*(n-1)/2 n∗(n−1)/2,交换次数为 ( n − 1 ) ∗ ( n − 2 ) / 2 (n-1)*(n-2)/2 (n−1)∗(n−2)/2。在最坏情况下,插入排序的时间复杂度与冒泡排序和选择排序相同,但是插入排序在最好情况下的时间复杂度为O( n n n),这是因为在最好情况下,插入排序不需要进行交换操作。此外,插入排序是一种稳定的排序算法。

四、C语言实现示例

c 复制代码
#include <stdio.h>
void insertion_sort(int arr[], int n) {
    int i, j, key;
    for (i = 1; i < n; i++) {
        key = arr[i];
        j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            j = j - 1;
        }
        arr[j + 1] = key;
    }
}
int main() {
    int arr[] = {12, 11, 13, 5, 6};
    int n = sizeof(arr) / sizeof(arr[0]);
    insertion_sort(arr, n);
    printf("Sorted array: \n");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");
    return 0;
}

运行结果:

复制代码
Sorted array:
5 6 11 12 13

五、总结

插入排序是一种简单直观的排序算法,其时间复杂度为O(n^2),空间复杂度为O(1)。插入排序在最好情况下的时间复杂度为O(n),是一种稳定的排序算法。在实际编程中,插入排序适用于数据量较小或者基本有序的场景。通过本文的学习,希望读者能够深入理解插入排序算法,并在实际编程中灵活运用。

相关推荐
汀、人工智能3 分钟前
[特殊字符] 第95课:冗余连接
数据结构·算法·链表·数据库架构··冗余连接
生信研究猿4 分钟前
leetcode 226.翻转二叉树
算法·leetcode·职场和发展
一只小白00017 分钟前
反转单链表模板
数据结构·算法
橘颂TA18 分钟前
【笔试】算法的暴力美学——牛客 WY22 :Fibonacci数列
算法
独小乐19 分钟前
012.整体框架适配SDRAM|千篇笔记实现嵌入式全栈/裸机篇
c语言·汇编·笔记·单片机·嵌入式硬件·arm·gnu
XWalnut30 分钟前
LeetCode刷题 day9
java·算法·leetcode
bIo7lyA8v30 分钟前
算法稳定性分析中的随机扰动建模的技术9
算法
谢白羽38 分钟前
vllm抢占机制详解
算法·vllm
Hello--_--World38 分钟前
Vue2的 双端 diff算法 与 Vue3 的 快速diff 算法
前端·vue.js·算法
坚持编程的菜鸟1 小时前
The Blocks Problem
数据结构·c++·算法