C语言中插入排序

在C语言中,插入排序是一种简单的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。以下是插入排序的C语言实现,以及每个步骤的文字讲解:

cs 复制代码
#include <stdio.h>

void insertionSort(int arr[], int n) {
    int i, key, j;
    for (i = 1; i < n; i++) {
        key = arr[i]; // 当前要排序的元素
        j = i - 1;

        // 将arr[i]与已排序好的序列arr[0...i-1]中的元素进行比较,找到合适的位置插入
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j]; // 将大于key的元素向后移动
            j = j - 1;
        }
        arr[j + 1] = key; // 将key插入到合适的位置
    }
}

int main() {
    int n, i;
    printf("请输入数组的长度: ");
    scanf("%d", &n);
    
    int arr[n];
    printf("请输入数组的元素(用空格分隔): ");
    for (i = 0; i < n; i++) {
        scanf("%d", &arr[i]);
    }

    // 对数组进行插入排序
    insertionSort(arr, n);

    // 输出排序后的数组
    printf("排序后的数组: ");
    for (i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    return 0;
}

文字讲解:

  1. 定义一个插入排序函数insertionSort,它接受一个整型数组和数组的长度作为参数。

  2. 在main函数中,首先提示用户输入数组的长度,并读取用户输入。

  3. 根据用户输入的长度,动态创建一个整型数组。

  4. 提示用户输入数组的元素,并通过循环读取每个元素。

  5. 调用insertionSort函数对数组进行排序。

  6. 在insertionSort函数中,使用一个for循环从数组的第二个元素开始遍历数组。

  7. 在每次迭代中,将当前元素(key)与已排序好的部分进行比较,找到合适的位置插入。

  8. 使用一个while循环,将大于key的元素向后移动,直到找到合适的位置。

  9. 将key插入到合适的位置。

  10. 在main函数中,输出排序后的数组。

相关推荐
明月看潮生3 分钟前
青少年编程与数学 02-016 Python数据结构与算法 14课题、动态规划
python·算法·青少年编程·动态规划·编程与数学
明月看潮生4 分钟前
青少年编程与数学 02-016 Python数据结构与算法 11课题、分治
python·算法·青少年编程·编程与数学
源客z20 分钟前
SD + Contronet,扩散模型V1.5+约束条件后续优化:保存Canny边缘图,便于视觉理解——stable diffusion项目学习笔记
图像处理·算法·计算机视觉
freyazzr1 小时前
Leedcode刷题 | Day30_贪心算法04
数据结构·c++·算法·leetcode·贪心算法
旅行的橘子汽水1 小时前
【C语言-全局变量】
c语言·开发语言·数据库
IT猿手1 小时前
动态多目标进化算法:基于知识转移和维护功能的动态多目标进化算法(KTM-DMOEA)求解CEC2018(DF1-DF14)
算法·动态多目标进化·动态多目标进化算法·动态多目标测试·动态多目标
AI技术控1 小时前
计算机视觉算法实现——SAM实例分割:原理、实现与应用全景
人工智能·算法·计算机视觉
安科瑞刘鸿鹏1 小时前
智能配电保护:公共建筑安全的新 “防火墙”
运维·网络·物联网·算法·安全·能源
明月看潮生2 小时前
青少年编程与数学 02-016 Python数据结构与算法 16课题、贪心算法
python·算法·青少年编程·贪心算法·编程与数学
沐墨专攻技术2 小时前
顺序表专题(C语言)
c语言·开发语言·数据结构·顺序表