c语言输出二进制
Ⅰ c语言以二进制输出
#include<stdlib.h>
#include<stdio.h>
voidmain(){
intnumber=43;charstring[100];
itoa(number,string,2);
printf("原数=%d二进制数=%s ",number,string);
}
这个可以满足你吗?让程序输出反码补码好像要求有点高。你根据我写的程序自己算一下反码补码并不是一件很难的事。
Ⅱ C语言中printf直接打出2进制数是%什么16进制是什么
C语言中,控制printf函数输出格式的是格式字符,printf没有直接打出2进制数的格式符,直接打出16进制的格式符是x格式符,即%x。
printf函数中输出的格式为printf("<格式化字符串>", <参量表>),格式化字符串由格式控制、和输出表列两部分组成,其中格式控制包含格式声明和普通字符。
格式声明由“%”和格式字符组成,如%d、%f等。它的作用是将输出的数据类型转换为指定的格式然后输出。普通字符是需要在输出时原样输出的字符。
(2)c语言输出二进制扩展阅读
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语言中,如何让计算机输出一个整数的二进制形式,
最常用的printf是没有按二进制形式输出的,不过这个功能要求也很容易自己实现啊。
voidDispBinary(intnum)
{
inti,j;
j=sizeof(int)*8;
for(i=0;i<j;i++)
{
printf("%d",(num>>(j-i-1)&0x1);
}
}
Ⅳ C语言中怎么输出数据的二进制
二进制数不能像十进制那样%d直接输出。
如果想输出一个数的二进制可以通过函数把其转成2进制字符串再将其输出。
itoa函数
原型:char*itoa(intvalue,char*string,intradix);
参数:int value 被转换的整数,char *string 转换后储存的字符数组,int radix 转换进制数,如2,8,10,16 进制等
功能:将任意类型的数字转换为字符串。在<stdlib.h>中与之有相反功能的函数是atoi。
参考代码:
1、
#include<stdlib.h>
#include<stdio.h>
intmain(void)
{
intnumber=10;
charstring[25];
itoa(number,string,2);
printf("十进制数:%d,二进制数:%s ",number,string);
return0;
}
/*
十进制数:10,二进制数:1010
*/
2、
voidprint_bin(intn)
{
intl=sizeof(n)*8;//总位数。
inti;
if(i==0)
{
printf("0");
return;
}
for(i=l-1;i>=0;i--)//略去高位0.
{
if(n&(1<<i))break;
}
for(;i>=0;i--)
printf("%d",(n&(1<<i))!=0);
}
Ⅳ 怎么用c语言输出二进制码
在C语言的标准输出中,有16进制,10进制和8进制的输出格式,但是没有二进制的输出格式。所以要想输出二进制,只能靠自己写函数进行输出了。
基本思想为通过移位操作+与操作取出各个位上的值,然后对其进行输出即可。
以32位无符号整型数据二进制输出为例,代码如下:
#include<stdio.h>
voidbinary_print(unsignedintv)
{
inti;
intbit;
intsize=sizeof(v)*8;
//这里的size是输入参数v的位数,直接用32代替也可以,但写成sizeof(v)*8这样更为通用。
for(i=0;i<size;i++)
{
bit=v&(1<<(size-i-1));//提取出第i位的值
if(bit==0)putchar('0');
elseputchar('1');
}
}
Ⅵ C语言中怎样输出一个二进制的数
//我们用按位运算符:右移>>和按位运算符与^,这两个功能就可以实现。
#include<stdio.h>
voidprintBinary(intnumber);//这是声明一个自定义的函数,让编译器知道我们造了一个这么个函数,功能:将整数以二进制形式输出。
intmain()
{
printBinary(22);//括号里面可以填上你要输出的整数,比如要输出22的二进制形式
return0;
}
voidprintBinary()//自定义一个函数printBinary
{
inttemp=sizeof(number)-1;//定义一个变量:如果你的编译器是32位的,也就是inttemp=31;
while(temp>=0)//temp是循环的次数,不需要纠结判断是>=还是>,写完之后检验一下就知道哪个对了。
intvalue=number>>temp^1;//a>>temp。temp移动后,是把这个整数的二进制形式中最后一位,依次与1进行按位与运算。假如temp=31,就是把这个整数的二进制形式右移31位,只剩下了这个整数的二进制形式的开头第一个数字,然后与1进行按位与运算。真则为1,假则为0。
printf("%d",value);//每次输出整数的二进制形式的一个数字,从开头开始输出。.
temp--;//按位右移循环,直到把整数内存中所有的位移完毕。从内存中二进制形式的第一位开始。
}
Ⅶ c语言的二进制数值如何直接输出
C标准没有输出二进制的,不过用itoa()可以实现到二进的转换
可以使用itoa函数把变量的数值转换成2进制字符串,再用输出函数输出。
用 法:char *itoa(int value, char *string, int radix);
详细解释:itoa是英文integer to array(将int整型数转化为一个字符串,并将值保存在数组string中)的缩写.
参数:value: 待转化的整数。
radix: 是基数的意思,即先将value转化为radix进制的数,范围介于2-36,比如10表示10进制,16表示16进制。
* string: 保存转换后得到的字符串。
返回值:char * : 指向生成的字符串, 同*string。
备注:该函数的头文件是"stdlib.h"
Ⅷ C语言中二进制的输出字符格式是什么
C语言不支持直接的
二进制
输出。要二进制输出,必须手动写函数。
用递归方式
代码
量相对较小,下面是一个示例:
void print_binary(int n) //将整型
数值
n二进制输出。
{
if(n == 0) return;
f(n>>1);
printf("%d",n&0x1);
}
执行过程为,依次输出高位值。
当输入100时,会输出 1100100
Ⅸ 如何在c语言中输出二进制数
可以用 %x格式 输出16进制数,16进制一位拉4位,按8421分布,就是2进制数。1个字节正好用2位16进制表示,转为8位2进制。
Ⅹ 用C语言直接输出内存中数据(二进制或十六进制)
C不支持二进制输出,只有八进制,十进制和十六进制三种形式,你可以用十六进制,方法是printf("%x",i);
首先这段代码就是错的。没有%p这种形式存在,另外它也不是输出i,而是j,还有怎么多出来一个花括号?