利用c语言详细介绍下插入排序

插入排序,被称为直接插入排序。它的基本思想是将一个记录插入到已经排好序的有序表中,从而一个新的、记录数增 1 的有序表。

一、图文介绍

我们还是使用数组【10,5,3,20,1],排序使用升序的方式,小的元素在前,大的元素在后:

1.1,内循环第一遍

我们第一遍从第二个元素开始往前比较,如果前面元素大于后面元素,则实现交换。

1.2,内循环第二遍

我们第二遍从第三个元素开始往前比较。

1.3,内循环第三遍

我们第三遍从第四个元素开始往前比较。

1.4,内循环第四遍

我们第四遍从第五个元素开始往前比较,最终结束外循环,完成排序。

二、算法实现

2.1,插入排序

我们用c语言写一个插入排序算法的函数:

cpp 复制代码
int * insertSort(int *arr,int len)
{
    int preIdx,cur;
    for(int i=1;i<len;i++) //从第二个元素开始
    {
        preIdx = i - 1;
        cur = arr[i];
        while(preIdx>=0&&arr[preIdx]>cur) //往前比较,如果前面数据足够大,则完成交换
        {
            arr[preIdx+1] = arr[preIdx];
            preIdx --;
        }
        arr[preIdx+1] = cur; //数据最终落位
    }
    return arr;
}

2.2,程序测试

cpp 复制代码
int main() {

    int a[]={10,5,3,20,1};
    int *p = insertSort(a,5);
    printf("the array a after sort is ");
    for(int i=0;i<5;i++){
        printf("%d ", *(p++));
    }

}
相关推荐
XH华4 小时前
初识C语言之二维数组(下)
c语言·算法
菜鸡中的奋斗鸡→挣扎鸡5 小时前
滑动窗口 + 算法复习
数据结构·算法
axxy20007 小时前
leetcode之hot100---240搜索二维矩阵II(C++)
数据结构·算法
Uu_05kkq8 小时前
【C语言1】C语言常见概念(总结复习篇)——库函数、ASCII码、转义字符
c语言·数据结构·算法
1nullptr10 小时前
三次翻转实现数组元素的旋转
数据结构
TT哇10 小时前
【数据结构练习题】链表与LinkedList
java·数据结构·链表
嵌入式科普10 小时前
十一、从0开始卷出一个新项目之瑞萨RA6M5串口DTC接收不定长
c语言·stm32·cubeide·e2studio·ra6m5·dma接收不定长
A懿轩A10 小时前
C/C++ 数据结构与算法【栈和队列】 栈+队列详细解析【日常学习,考研必备】带图+详细代码
c语言·数据结构·c++·学习·考研·算法·栈和队列
1 9 J11 小时前
数据结构 C/C++(实验五:图)
c语言·数据结构·c++·学习·算法
汝即来归11 小时前
选择排序和冒泡排序;MySQL架构
数据结构·算法·排序算法