在C中int的取值范围为什么是这样的
来源:百度知道 编辑:UC知道 时间:2024/05/16 17:10:06
为什么不是1111111111111111-0111111111111111
在C中,int是一个有符号的整数,其最高位表示符号。0为+,1为-。
在计算机中,通常采用补码来表示一个二进制的数。
根据补码的原则,正数的补码为其本身,负数的补码为其对应的二进制代码去反加1。
故正数最大值(111 1111 1111 111)在C中表示为:
0 1111111 11111111=2^15-1=32767
0表示为:0000 0000 0000 0000
-1000 0000 0000 0000 = -2^15= -32768
上述二进制代码的补码为: 1000 0000 0000 0000 ,由于所有补码体系中没有代码与该值重合,于是就人为的定义为负值的最小值了。
因此,C中INT的取值范围为: 1000 0000 0000 0000 - 0111 1111 1111 1111
-32768~32767
.同意楼上的说发啊
那你说float 和double 的取值是为什么呢
在C中int的取值范围为什么是这样的
在C语言中为什么int型的取值范围是-32768~32767
在turbo c中 Int型变量的取值范围是怎样计算出来的?
听说c语言中int等数值型数据的取值范围是取决于电脑......
C语言中putpixel(int x,int y,int color)中color的取值范围和具体介绍
为什么在 c语言中,int 有个范围,这个范围怎么计算的?
C++中,int型数据的取值范围是多少?
在C语言中为什么int型的取址范围为-2的15次方到2的15次方减1?
在Rt△ABC中,∠C=90°,则(a+b)/c的取值范围是?
c语言中无符号和有符号的整形变量在 表示字符数据是为什么取值范围不一样?能解释下么?~谢谢~