交换一个无符号整形数的奇偶位

本文探讨了在数据处理中使用高效位操作算法的实现方式,通过具体实例展示了如何利用位运算进行快速数据交换和位移操作,提高了算法的执行效率。重点介绍了三种不同的位操作算法,并对比了它们的性能表现。

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

void OddEventBitSwap1(unsigned &A)
{
    unsigned int mask = 0x3;
    int loop = sizeof(unsigned)*8/2;

    for(int idx = 0; idx < loop; idx++)
    {
        if (((A & mask) != mask) && ((A & mask) != 0))
        {
            A = A^mask;
        }
        mask = mask << 2;
    }
}

void BitSwap(unsigned &A, int pos1, int pos2)
{
    unsigned p1Value = ((0x1<<pos1)&A)>>pos1;
    unsigned p2Value = ((0x1<<pos2)&A)>>pos2;

    A = A & (~((0x1<<pos1 | 0x1<<pos2)));

    A = A | (p1Value<<pos2);
    A = A | (p2Value<<pos1);
}


void OddEventBitSwap2(unsigned int &A)
{
    int loop = sizeof(unsigned)*8/2;
    int even = 0; 
    int odd = 1;
    for (int idx = 0; idx < loop; idx++)
    {
        BitSwap(A, odd, even);
        odd += 2;
        even += 2;
    }
}


void OddEventBitSwap3(unsigned int &A)
{
    unsigned int oddValue  = A & 0X55555555;
    unsigned int evenValue = A & 0XAAAAAAAA;

    A = (oddValue<<1 | evenValue>>1);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值