C语言——插入排序

先将序列的第1个记录看成是一个有序的子序列,然后从第2个记录逐个进行插入,直至整个序列有序为止。

#include <stdio.h>

#include <stdlib.h>

void insertion_sort(int *arr, int n)

{

for (int i = 1; i < n; i++)

{

int key = arr[i];

int j = i - 1;

while (j >= 0 && key < arr[j])

{

arr[j + 1] = arr[j];

j--;

}

arr[j + 1] = key;

}

}

void print_arry(int *arr,int n)

{

for (int i = 0; i < n; i++)

{

printf("%d ", arr[i]);

}

}

int main()

{

int n;

scanf_s("%d", &n);

int *arr = (int *)malloc(sizeof(int) * n);

if (arr == NULL)

{

return 1;

}

else

{

for (int i=0; i < n; i++)

{

scanf_s("%d", arr + i);

}

insertion_sort(arr, n);

print_arry(arr, n);

}

free(arr);

return 0;

}

使用了malloc函数动态开辟内存空间,最后记得要释放。

自定义了两个函数模块,一个是插入排序函数,一个是打印函数

结果

相关推荐
ytttr87317 分钟前
基于MATLAB的Relief算法特征权重选择实现
算法
czy87874751 小时前
C语言实现状态模式
c语言·状态模式
Freshman小白1 小时前
python算法打包为docker镜像(边缘端api服务)
python·算法·docker
czy87874751 小时前
C语言实现迭代器模式
c语言·迭代器模式
mit6.8242 小时前
[VT-Refine] Simulation | Fine-Tuning | docker/run.sh
算法
朴shu2 小时前
Delta数据结构:深入剖析高效数据同步的奥秘
javascript·算法·架构
野生技术架构师2 小时前
牛客网Java 高频面试题总结(2025最新版)
java·开发语言·面试
一只鹿鹿鹿2 小时前
系统安全设计方案书(Word)
开发语言·人工智能·web安全·需求分析·软件系统
GilgameshJSS2 小时前
STM32H743-ARM例程36-DNS
c语言·arm开发·stm32·单片机·嵌入式硬件
持梦远方2 小时前
【C++日志库】启程者团队开源:轻量级高性能VoyLog日志库完全指南
开发语言·c++·visual studio