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;
}
哈哈,这是我用的方法。大家觉得我这方法靠谱不
|