C语言实现直接插入排序

完整代码:

复制代码
#include<stdio.h>

//直接插入排序,从小到大
//参数:arr[]表示待排序数组,len表示该数组长度
void insert_sort(int arr[],int len){
    //arr[i]表示待插入的那个数
    //tmp保存待插入那个数的值
    //arr[j]用来移动数据
    int i,j,tmp;
    //默认第一个数,即arr[0]是已经排序好的,所以i从1开始遍历
    for (int i = 1; i < len; i++)
    {
        //如果待插入的数大于等于它之前已经排序好的序列,就不用做任何处理,如果小于的话就应该做以下处理
        if (arr[i]<arr[i-1])
            {
                //用tmp保存数值,防止被移动过来的数覆盖
                tmp=arr[i];
                //j=i-1,就是从待插入数前面的那个数开始移动,如果比待插入数大,就往后移动,然后j--,从后往前遍历已经排序好的序列,直到小于或者等于待排序的数
                //如果j=0,就说明待排序的数是当前已经排序好的序列里最小的数,所以要把arr[j]的位置让给待插入数
                for (j=i-1;j >=0&&arr[j]>tmp; j--)
                {
                    //往后移动
                    arr[j+1]=arr[j];
                }
                //全部移动完成后,将待插入数插入,此时又形成一个排好序的序列
                arr[j+1]=tmp;
        }
    }
}

int main(){
    int arr[10]={3,2,1,7,5,9,8,4,10,6};
    insert_sort(arr,10);
    for (int i = 0; i < 10; i++)
    {
        printf("%d ",arr[i]);
    }
    return 0;
}

运行截图:

相关推荐
SHARK_pssm17 分钟前
【数据结构——树与堆】
c语言·数据结构·经验分享·笔记
bIo7lyA8v37 分钟前
算法可视化对教学与调试效率的影响分析的技术8
算法
郝学胜-神的一滴43 分钟前
CMake 017:彩色日志输出实战
linux·c语言·开发语言·c++·软件工程·软件构建·cmake
hunterkkk(c++)1 小时前
优先队列启发式最短路径快速算法(优化SPFA)-HEAP_SPFA算法
算法
SiliconGazer1 小时前
第15届国赛满分代码解析(下)—— 运动轨迹算法、按键交互与完整状态机
算法·状态机·stc15f2k60s2·浮点运算·蓝桥杯国赛·运动轨迹、·向量分解
Navigator_Z1 小时前
LeetCode //C - 1096. Brace Expansion II
c语言·算法·leetcode
luj_17681 小时前
FreeDOS vs MS-DOS PC-DOS 对比解析
服务器·c语言·开发语言·经验分享·算法
笨笨没好名字1 小时前
Leetcode刷题python版第一周
python·算法·leetcode
Cthy_hy1 小时前
斯特林数:组合划分的递归经典,一二两类全解
python·算法·斯特林数
不忘不弃1 小时前
计算pi的近似值
算法