您的位置:

c语言中如何输出二进制,c语言如何以二进制输出

本文目录一览:

C语言中printf直接打出2进制数是%什么?16进制是什么?

C语言中,控制printf函数输出格式的是格式字符,printf没有直接打出2进制数的格式符,直接打出16进制的格式符是x格式符,即%x。

printf函数中输出的格式为printf("格式化字符串", 参量表),格式化字符串由格式控制、和输出表列两部分组成,其中格式控制包含格式声明和普通字符。

格式声明由“%”和格式字符组成,如%d、%f等。它的作用是将输出的数据类型转换为指定的格式然后输出。普通字符是需要在输出时原样输出的字符。

扩展资料

C语言printf函数格式字符:

1、%d,按整型数据的实际长度输出。

2、%md,m为指定的输出字段的宽度。

3、%ld,输出长整型数据。

4、o格式符,以八进制整型式输出整数。

5、x格式符,以十六进制数形式输出整数。

6、u格式符,用来输出unsigned型数据,即无符号数,以十进制形式输出。

7、c格式符,用来输出一个字符。

8、s格式符,用来输出一个字符串。

9、f格式符,用来输出实数(包括单双精度),以小数形式输出。

10、e格式符,以指数形式输出实数。

11、g格式符,用来输出实数,它根据数值的大小,自动选f格式或e格式(选择输出是占宽度较小的一种),且不输出无意义的零。

12、p格式符,用于变量地址的输出。

13、%[scanfset]:

scanfset 有两种形式:一种是以非 “^” 字符开头的 scanset , 表示在读入字符串时将匹配所有在 scanfset 中出现的字符,遇到非scanfset 中的字符时输入就结束;

另外一种形式是以 “^” 字符开头的scanfset ,表示在读入字符串时将匹配所有不在scanfset 中出现的字符,遇到scanfset 中的字符输入就结束。

参考资料来源:百度百科——格式字符

C语言中怎样输出一个二进制的数?

//我们用按位运算符:右移 和按位运算符与^,这两个功能就可以实现。

#includestdio.h

void printBinary(int number);//这是声明一个自定义的函数,让编译器知道我们造了一个这么个函数,功能:将整数以二进制形式输出。

int main() 

{

printBinary(22);//括号里面可以填上你要输出的整数,比如要输出22的二进制形式

return 0;

}

void printBinary()//自定义一个函数printBinary 

{

int temp = sizeof(number)-1;// 定义一个变量 :如果你的编译器是32位的,也就是int temp = 31;

while(temp = 0) // temp 是循环的次数,不需要纠结判断是= 还是, 写完之后检验一下就知道哪个对了。

int value = numbertemp^1;// atemp。temp移动后,是把这个整数的二进制形式中最后一位,依次与1进行按位与运算。假如temp=31,就是把这个整数的二进制形式右移31位,只剩下了这个整数的二进制形式的开头第一个数字,然后与1进行按位与运算。真则为1,假则为0。

printf("%d", value);//每次输出整数的二进制形式的一个数字,从开头开始输出。. 

temp--;// 按位右移循环,直到把整数内存中所有的位移完毕。从内存中二进制形式的第一位开始。

}

如何在c语言中输出二进制数???

可以用

%x格式

输出16进制数,16进制一位拉4位,按8421分布,就是2进制数。1个字节正好用2位16进制表示,转为8位2进制。

C语言中怎么输出数据的二进制

C语言中,默认支持16进制的数据输出,其实这个就是一个更容易阅读的二进制显示。

C语言的标准库,没有二进制输出函数,需要自己写,写法主要有两种:

1.

除以2和对2取余数的循环;

2.

位移操作和位与()操作;

第二种效率高些:

int dat = 12345;

int ibit = 0x01;

for(int i=31;i=0;i--){

a[i] = (dat ibit)==0 ? 0,1;

ibit 1;

}

for(i=0;i32;i++)

printf("%d",a[i]);