c语言中int取值范围-2的15次方至2的15次方减1,为什么要减1?
1个回答
2022-12-11 · 百度认证:北京惠企网络技术有限公司官方账号
关注
展开全部
根据你的提问,你说的int是占2个字节。\x0d\x0a1、首先int是有符号的,也就是有正负之分。\x0d\x0a对于负数,那么最高位为不变的值,是1,那么还有15个位,就有2^15个情况。\x0d\x0a对于正数,最高位是0,也有2^15个情况。\x0d\x0a但是你注意,这2中情况有一个数重复了,那就是 负0 和 正 0\x0d\x0a正数0: 0 0000000 00000000\x0d\x0a负数0,计算机中其实没有负数0,正数0和负数0一样的,为什么会一样呢?因为数字采用补码存储在计算机中。所以正负0都是一样的编码。具体补码你可以百度。\x0d\x0aint的负数范围 :[ 1 1111111 11111111~ 1 0000000 00000001 ] \x0d\x0a\x0d\x0aint的非负范围 : [ 0 0000000 00000000~ 0 1111111 11111111 ] 32767\x0d\x0a\x0d\x0a你可以看一下,正数的最大值是 32767,而2^15==32768,之所以这样,是因为,\x0d\x0a2^15代表 15个位可以有多少个不同的数,而不是指最大值。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询