⑴ 在c语言中 2 进制8进制16进制中都怎么表示负数如何定义类型如何输出
8进制和16进制无符号(unsigned)类型
用0***表示八进制数,如0123表示八进制数123
用0x***表示16进制数,如0x1a表示16进制数1A
八进制数和16进制数都可存放于unsigned int中
输出时,八进制标识符%o 16进制%x
⑵ 在c语言中怎么表示负数。
第一位符号位1为负,0为正。 正数的补码和2进制原码是一样的。
负数的补码:
1、先取绝对值|x| ;
2、对|X|+1 ;
3、对|X|+1 取反,就得到它的补码了 。
计算机中存放整型数据都是按补码的形式存放的。
(2)c语言负数是什么类型扩展阅读:
有符号数的表示方法是由硬件决定,而不是由C决定的。有三种表示方法:
1、二进制原码
0000 0001 表示 1
1000 0001 表示 -1
这个方法有个缺点是有两个零: +0 和 -0。这会引起混淆,而且用两个位组合来表示一个值也有些浪费。
2、二进制补码(最普遍的系统)
区别在于 singned 和 unsigned:
1)如果是无符号字节, 1000 0000 该组合为 128
2)如果是有符号字节, 1000 0000 该组合为 -128
第一种表示数的范围是 0 ~ 255;
第二种表示数的范围是 -128 ~ +127,对于一个二进制补码数取负数,最简单的方法就是取反、加 1。
3、二进制反码
通过反转位组合中的每一位以形成一个数的负数,例如:
0000 0001 表示 1
1111 1110 表示 -1
这种方式也有一个 -0:1111 1111。其范围是 -127 ~ +127。
⑶ C语言里负数是整数吗
在VC C++上是正常啊
将整个程序复上来看看
它是指声明部分是整数吧,
如int c = 1e-3;
printf("%d\n", c);
输出就一定是0,因为int只能保存是整数嘛;修改为float就正常了(输出变成%f)。
⑷ c语言中负数如何表示
c语言中负数表示方法就是在数前加负号“-”,比如:
-5,-10000,等
一个变量赋值为负数也是如此,比如:
x=-1000;
⑸ 请问c语言中的int类型-32768〜32767的负数是什么,详细的,不能超出这个范围值
C语言如果使用16位系统,那么int类型的有效位数就是16位(二进制数)
其中最高位代表正数(包括0)和负数的标识,0代表正,1代表负
负数一律使用补码表示,即将这个负数相对应的正数所有位取反(1变0,0变1),再加1,即得补码
而-32768是16位二进制(补码)能表示的最小负整数,32767为16位二进制去掉最高位后能表示的最大正整数。
如1的二进制表示是15个0,最后一位是1
-1的二进制表示为 16个1
0的二进制表示为 16个0
-32768 的二进制表示为 最高位1 后面15个0
32767 的二进制表示为 最高位0 后面15个1
⑹ C语言里负数是整数吗
不一定,这个负整数要在int的范围内
int型范围在 -32768到32767之间
⑺ 为什么c语言负数是以补码形式存放的
以-1和+1相加为例子。
一个字节,如果是负数,它是255,如果是正数,它是
-1。
255+1
=
256(1,0000,0000)
-1+1
=
0(0,0000,0000)
因为加到256后并不会真的进位,而是把op置位。所以整负数相加的问题很多地方都可以不去理会了。不用真正去区分正负了,只要依据最后需要的类型去处理结果就可以。
⑻ C语言如何表示正负值问题
c语言有两种数据类型,一种是整型,一种是浮点型 ,整型类型一般用的原码表示,浮点类型一般用的IEEE754标准进行编码。
整型数中原码表示正负数,取最高位为符号位,以8位二进制数来表示1和-1。1的二进制为
0 000 0001 //最高位为符号位,0表示正数,1表示负数
1 000 0001 //这个表示-1
IEEE754浮点数编码,使用的格式类似于 (-1)^s * M* 2^E,其中s是符号位,M是有效位数,E指的是指数,s符号位占1位,如果是0,则(-1)的0次方为1,表示是一个正数,如果s位是-1,则表示是一个负数。
⑼ c语言中负数是按补码存储,怎么读出来哪
本质是,都是二进制数,或者是十六进制数。
举个例子:
-1,在16位CPU中,用补码表示,则为1111 1111 1111 1111,或者0xFFFF。
在C语言中,如果定义为无符号数,则0xFFFF读出来就是65535,
如果定义为有符号数,则0xFFFF读出来就是-1。
同样的二进制数,类型不同,解释出来的结果也不同。