https://mp.weixin.qq.com/s/Ednvz9F9cTXvW9mzA8Lj-g
这是论坛微信公众号上的**。
其实我看到这个题目想到的是用数据结构来求。
方法:结构体与联合体。
为了简单起见,我将文中求32位数字,换成了8位数字。其实多添加一下结构体就行了。
- #include <stdio.h>
- #include <stdlib.h>
- struct bb
- {
- unsigned b0:1;
- unsigned b1:1;
- unsigned b2:1;
- unsigned b3:1;
- unsigned b4:1;
- unsigned b5:1;
- unsigned b6:1;
- unsigned b7:1;
- };
- union aa
- {
- struct bb bx;
- unsigned char x;
- };
- int val;
- int main()
- {
- union aa y;
- y.x=0xDF;
- val=y.bx.b0+y.bx.b1+y.bx.b2+y.bx.b3+y.bx.b4+y.bx.b5+y.bx.b6+y.bx.b7;
- printf("b=%d\n",val);
- return 0;
- }
哈哈,这是我用的方法。大家觉得我这方法靠谱不
|