插入排序

不解释,直接上代码

#include <stdio.h>


void insert(int arry[], int iIndex)
{
        int iSaved = arry[iIndex];
        int iPos = iIndex-1;
        while(iPos>=0 && iSaved<arry[iPos])
        {
                arry[iPos+1] = arry[iPos];
                --iPos;
        }
        arry[iPos+1] = iSaved;
}


int main()
{
        const int iarrynum = 10;
        int arry[] = {10,9,8,7,6,5,4,3,2,1};
        printf("old order:\n");
        for(int i=0; i<iarrynum; ++i)
        {
                printf("%d\t",arry[i]);
        }
        printf("\n");
        for(int i=1; i<iarrynum; ++i)
        {
                insert(arry,i);
        }


        printf("new order:\n");
        for(int i=0; i<iarrynum; ++i)
        {
                printf("%d\t",arry[i]);
        }
        printf("\ndone.\n");
}


做算法还是要写纯C,gcc编译不通过,将for中的变量提到外面。

如果是基于指针的插入排序,只需将参数转换为指针形式,并将比较函数作为回调函数

void sortPointer(void** ar,int index, int(*cmp)(const void*, const void*))
{
        void* saved = ar[index];        
        int iPos = index-1;
        while(iPos>=0 && cmp(ar[iPos],saved)>0)
        {
                ar[iPos+1] = ar[iPos];
                iPos--;
        }
        ar[iPos+1] = saved;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值