C语言基本算法

1.冒泡排序

/**<  冒泡排序从小到大排序*/
void bubble_pos_sort(u8 *data,u16 len)
{
    u8 i,j,buff;
    for(i=0;i<len;i++){
        for(j=0;j<len-i-1;j++){
            if(data[j] > data[j+1]){
                buff = data[j];
                data[j] = data[j+1];
                data[j+1] = buff;
            }
        }
    }
}

/**<  冒泡排序从大到小排序*/
void bubble_rever_sort(u8 *data,u16 len)
{
    u8 i,j,buff;
    for(i=0;i<len;i++){
        for(j=0;j<len-i-1;j++){
            if(data[j] < data[j+1]){
                buff = data[j];
                data[j] = data[j+1];
                data[j+1] = buff;
            }
        }
    }
    for(i=0;i<len;i++){
        printf("%4d",data[i]);
    }
    printf("\r\n");
}
  1. 二分法查找
/**< 二分法查找函数:查找的对象必须是从小到大排序了的 */
/** \brief
 *
 * \param dest:查询的目标数据
 * \param src:源数据(数组)
 * \param len:数据长度
 * \return 1:找到对应的数据,0:反之
 *
 */
u8 binary_serch(u8 dest,u8 *src,u16 len)
{
    u8 low,high,mid,serch_flag;
    u8 is_exist=0;
    low = 0;
    high = len-1;
    while(low<high)
    {
        mid = (low + high)/2;
        if(dest<src[mid])
        {
            high = mid - 1;
        }else if(dest>src[mid]){
            low = mid +1;
        }else if(dest == src[mid]){
            is_exist = 1;
            break;
        }
    }
    return is_exist;
}
  • 0
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值