2.6 编写一个函数setbits(x, p ,n, y),该函数返回对x执行下列操作后的结果值: 将x中从第p位开始的n个(二进制)位设置为y中最右边n位的值,x的其余各位保持不变。

题目分析:

xxx...xnnnx...xxx     x

yy..............ynnn    y

要变成这样的效果。

我们需要对x中n位清零,把y中最右边n位其他以为的位都清零并左移到第p位处,然后进行or操作。

xxx....x000x...xxx

000...  nnn....000     |

--------------------------

xxx....xnnnx...xxx

1.对x中n位清零:  这里想到与运算,x中n位与零相与n位得到0,其余位与1相与(这样可以保持其他位不变)。

  ~(~0<< n): 得到最低n位为1,其余各位为0的位串信息。000......111

将~(~0<< n)左移(p+1-n) 位得到 000..01110...000

然后取反得到 111...10001.111

最后与x相与可得到 xxx...x000x...xxx

2. 对y处理:

运用   ~(~0<< n): 得到最低n位为1,其余各位为0的位串信息。000......111

然后与y相与得到 000......0nnn

最后左移(p+1-n)  得到 000...nnn....000

 

代码如下:

/* setbits : set n bits of x at position p with bits of y */

unsigned setbits ( unsigned x, int  p, int n, unsigned y)

{

    return x &~(~(~0<< n) << (p + 1 -n)) | (y & ~(~0 <<n )) << (p + 1 - n)
  }

}

                        

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值