给定一个整数实现奇偶比特位互换

上次参加创新工场笔试,有个题目叫做定义一个宏实现,给定一个整数,进行奇偶比特位互换,比如整数6互换之后就变成9,当时毫无头绪,回头想想也不是很难

思路如下:

左移一位,则偶数位到了奇数位,将偶数位清零

右移一位,则奇数位到了偶数位,将奇数位清零

  让两者相加,则得结果

        32位的整数,那么如何让偶数位清零,我们知道任何比特位与1相与是其本身,与0相与变为0,因而若想将偶数位清零,则对应的数位01010101 01010101 01010101 01010101 同理,将奇数位清零则为 1010101010101010 10101010 10101010

我们将两者相加发现什么呢

11111111  11111111  11111111  11111111  偌,-1的补码额

也就是说将偶数位清零的数为 ((unsigned)(-1))/3

将奇数位清零的数为2*((unsigned)(-1))/3

则将偶数位到奇数位的宏为 #d

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值