解题思路:
首先,审题,要求“从右端开始的第4至7位”是从第0位开始的,有小伙伴可能会在这里出错。
解题思路是先将原数217(0000 0000 1101 1001)通过一次右移(>>)和一次左移(<<),将右端开始的第0位至第7位变成‘0’,即(0000 0000 0000 0000)。
然后,将原数与变化后的数进行按位异或(^)操作,得到(0000 0000 1101 1001)。
最后,将得到的数向右移(>>)4个单位,得到目标答案。
注意事项:
这样的思路优点在于,不需要额外找数来和原数进行位运算,原数可以通过先后一次右移和一次左移得到所需要的辅助数。
参考代码:
#include<stdio.h>
int main()
{
unsigned int num, binary, temp;
scanf("%u", &num);
temp = num >> 8; //一次右移(>>)
temp = temp << 8; //一次左移(<<)
binary = num ^ temp;
binary = binary >> 4;
printf("%u\n", binary);
return 0;
}
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:521 |
母牛的故事 (C语言代码)浏览:1427 |
DNA (C语言描述,蓝桥杯)浏览:1553 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:520 |
C语言程序设计教程(第三版)课后习题6.2 (C语言代码)浏览:534 |
C语言程序设计教程(第三版)课后习题10.3 (C语言代码)浏览:509 |
交换Easy (C语言代码)浏览:759 |
第三届阿里中间件性能挑战赛-总决赛亚军比赛攻略浏览:1144 |
C语言程序设计教程(第三版)课后习题11.3 (C语言代码)浏览:635 |
C语言程序设计教程(第三版)课后习题8.6 (C语言代码)浏览:585 |