C语言怎么定义一个二进制数

比如 我要定义a=0000 0000;a1=0000 0001;等等,然后我还需要将a和a1按位异或
求指点

C语言中没有 “二进制数”这种类型,所以没办法直接定义;但可以直接定义16进制数。

例:

int main(){

int a;

scanf("%p",&a);//16进制数输入%p是输入一个十六进制的数scanf("%llx",&a);也可以输入十六进制并且比较正规

printf("%d",a);//十进制输出%d是输出一个十进制的数

printf("0x%x",a);//16进制输出printf("%llX\n",a);也可输出一个十六进制数如果红色部分大写X则输出十六进制为大写字母否则小写x输出为小写字母

}

扩展资料

C语言中定义整型数据的十六进制数:

unsigned int hex_val = 0x123;

//定义了一个整型变量并赋以初始值为一个十六进制常量

if (scanf("%x", &hex_val) != EOF)

{

printf("它的八、十进制分别=%o、%d\n", hex_val, hex_val);

}

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-07-22

需要准备的材料分别有:电脑、C语言。

1、首先,打开C语言编译器,新建一个初始.cpp文件,例如:test.cpp。

2、在test.cpp文件中,输入C语言代码:int a = 0b00000000;int a1 = 0b00000001;printf("%d", a^a1); 。

3、编译器运行test.cpp文件,此时成功定义了并进行了异或运算后输出了。

本回答被网友采纳
第2个回答  推荐于2017-09-05
C语言中没有 “二进制数”这种类型,实际上在程序当中,一切内容都是以二进制保存的。但是没有办法直接定义二进制数,只有8,10,16进制可以直接用来定义。
C语言中的数据基本类型包括:char short int long float double . 用哪种类型定义的就叫XX类型变量,如字符型变量,整型变量,浮点型变量。
各种变量中存储的数据,都是以二进制进行存储的。因类型的不同,采用的二进制编译格式不同。如:整形类都是用补码存储,浮点型采用IEEE754标准存储。
对于int a=0x1A ; int b=0101 ;这种变量初始化中,a,b依然是整形变量,0x1A这种以0x开头的数据表示16进制常数(或称常量),0101这种以0开头的数字表示8进制常数。但程序设计中并没有规定二进制常数的表示形式,如果需要使用的话,可以采用字符数组来存储二进制数,如:
char a[100] = "10100101" ;
需要运算时,再通过自定义函数将字符串转换成整数。
第3个回答  2013-05-04
额,正常定义一个整数也可以按位异或呀~如果你只是要得到某两个数按位异或的结果的话,只要用“|”运算符按位异或就行了,详情可搜索“位运算”,不需要特地定义成0x啥啥啥的本回答被提问者采纳
第4个回答  2013-05-03
用16进制表示
对于你的两个例子:
int a = ox 00;
int a1 = 0x01;

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网