求将一个数的二进制位逆序算法

本文介绍了如何通过位操作实现对1字节、2字节和4字节数据的二进制位颠倒。通过具体的C语言函数实现,展示了从输入到输出的位颠倒过程,适用于需要进行位级数据处理的应用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

//输入1个字节,将其二进制位颠倒后,再输出1个字节
//比如input:0110 0101   output:1010 0110
uint8_t bit8_order_reverse(uint8_t ch)
{
    uint8_t ch_new = 0;
    uint8_t bit_val = 0x80;
    uint8_t bit_val_reverse = 0x01;
    while (bit_val)
    {
        if (ch & bit_val)
        {
            ch_new |= bit_val_reverse;
        }
        bit_val >>= 1;
        bit_val_reverse <<= 1;
    }
    return ch_new;
}

//输入2个字节,将其二进制位颠倒后,再输出2个字节
//比如input:0110 0101 1011 1101  output:1011 1101 1010 0110
uint16_t bit16_order_reverse(uint16_t ch)
{
    uint16_t ch_new = 0;
    uint16_t bit_val = 0x8000;
    uint16_t bit_val_reverse = 0x0001;
    while (bit_val)
    {
        if (ch & bit_val)
        {
            ch_new |= bit_val_reverse;
        }
        bit_val >>= 1;
        bit_val_reverse <<= 1;
    }
    return ch_new;
}

//输入4个字节,将其二进制位颠倒后,再输出4个字节
uint32_t bit32_order_reverse(uint32_t ch)
{
    uint32_t ch_new = 0;
    uint32_t bit_val = 0x80000000;
    uint32_t bit_val_reverse = 0x00000001;
    while (bit_val)
    {
        if (ch & bit_val)
        {
            ch_new |= bit_val_reverse;
        }
        bit_val >>= 1;
        bit_val_reverse <<= 1;
    }
    return ch_new;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值