按位反转字符串与整数

一、按位反转字符串
Write a C function to swap the bits of a unsigned char so that its bits become the mirror image of the char. MSBs become its LSBs, e.g.  01111000 binary should become 00011110 binary.

 

方法一:(最最容易想到的办法)

unsigned char ReverseBitsInChar00(unsigned char Num)

{

    unsigned char ret = 0;

    int i;

    for(i=0;i<8;i++)

    {

       ret <<= 1;

       ret |= Num & 1;

       Num >>=  1;

    }

 

    return ret;

}

上面的程序通过每次取传入参数的最后一位( Num & 1),然后与要返回的结果相 “ 或 ”,把传入参数 Num 右移 1 位,要返回的结果左移一位,来实现数字反转的。

 

 方法二:  (对换)

unsigned char ReverseBitsInChar01(unsigned char Num)

{

    unsigned char ret = 0;

    int i;

 

    for(i=0;i<4;i++)

    {

         ret |= (Num & (1 << i)) << (7-2*i);

         ret |= (Num & (0x80 >> i) ) >> (7-2*i);

    }

 

    return ret;

}

上面的程序通过对换来实现的。

1、先找到低位,然后移动到对应的高位,再与要返回的结果 或 。

2、再找到高位,然后移动到对应的低位,再与要返回的结果 或。

3、循环,直至对换 4 次。

 

方法三:   (分而治之)

unsigned char ReverseBitsInChar02(unsigned char Num)

{

    Num = (Num & 0x55) <<  1  | (Num >>  1) & 0x55;

    Num = (Num & 0x33) <<  2  | (Num >>  2) & 0x33;

    Num = (Num & 0x0F0F) <<  4  | (Num >>  4) & 0x0F0F;

 

    return Num;

}

上面的程序采用的是分而治之的策略( divide and conquer strategy )。把反转32

位的程序分别分解为反转 2 位、4 位来实现的。无论是对于要反转几位,他们的算法是类似的。

1、取低位,左移。

2、右移,取高位。

3、( 1、2 的结果) 或

 

方法四:   (分而治之)

 

unsigned char ReverseBitsInChar03(unsigned char Num)

{

    Num = (Num & 0x55) <<  1 | (Num & 0xAA) >>  1;

    Num = (Num & 0x33) <<  2 | (Num & 0xCC) >>  2;

    Num = (Num & 0x0F) <<  4 | (Num & 0xF0) >>  4;

 

    return Num;

}

这个程序采用的也是分而治之的策略( divide and conquer strategy )。把反转32

位的程序分别分解为反转 2 位、4 位来实现的。无论是对于要反转几位,他们的算法是类似的。

 

1、取低位,左移。

2、取高位,右移。

3、( 1、2 的结果) 或

二、按位反转整数
因为整数的长度为32位,所以要进行32位的反转,代码都差不多,现在只写出一个算法吧,其它的同上:

unsigned int ReverseBitsInWord03(unsigned int Num)

{

    Num = (Num & 0x55555555) <<  1 | (Num & 0xAAAAAAAA) >>  1;

    Num = (Num & 0x33333333) <<  2 | (Num & 0xCCCCCCCC) >>  2;

    Num = (Num & 0x0F0F0F0F) <<  4 | (Num & 0xF0F0F0F0) >>  4;

    Num = (Num & 0x00FF00FF) <<  8 | (Num & 0xFF00FF00) >>  8;

    Num = (Num & 0x0000FFFF) << 16 | (Num & 0xFFFF0000) >> 16;

 

    return Num;

}

 

这个程序采用的也是分而治之的策略( divide and conquer strategy )。把反转32位的程序分别分解为反转 2 位、4 位、8位、16位来实现的。无论是对于要反转几位,他们的算法是类似的。

1、取低位,左移。
2、取高位,右移。
3、( 1、2 的结果) 或


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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值