2 u014075789 u014075789 于 2016.01.19 23:13 提问

机器数字长为八位(含一位符号位),当x=-128(十进制)时,其对应的二进制为?

机器数字长为八位(含一位符号位),当x=-128(十进制)时,
其对应的二进制为? ,[x]原= ?,[x]反= ?,[x]补= ?,[x]移= ?
主要是问对应的二进制为? (源码 补码 移码不用回答)
-1 对应的二进制是 -000 0001 -128呢??? 郁闷 求解

5个回答

caozhy
caozhy   Ds   Rxr 2016.01.19 23:26

10000000

原码:11111111
反码:10000000
补码:10000001

caozhy
caozhy 回复u014075789: -1的二进制是11111111,-128是10000000(8位有符号表示)
2 年多之前 回复
u014075789
u014075789 对应二进制呢?
2 年多之前 回复
caozhy
caozhy 回复u014075789: 负数由符号位和补码构成,-1才是11111111
2 年多之前 回复
u014075789
u014075789 当x= -1 (十进制),对应的二进制为 -0000001 那么-128呢?
2 年多之前 回复
caozhy
caozhy   Ds   Rxr 2016.01.19 23:27

移码: 00000000

l294265421
l294265421   2016.01.20 08:09
91program
91program   Ds   Rxr 2016.01.20 08:33

概念介绍:
计算机中的信息都是以二进制形式表示的,数值有正负之分,计算机就用一个数的最高位存放符号(0为正,1为负)。这就是机器数的原码了。设机器能处理的位数为8。即字长为1byte,原码能表示数值的范围为(-127~-0 + 0~127)共256个。

有了数值的表示方法就可以对数进行算术运算。但是很快就发现用带符号位的原码进行乘除运算时结果正确,而在加减运算的时候就出现了问题,如下(假设字长为8bits):
(1)10- (1)10 = (1)10 + (-1)10 = (0)10
(00000001)原 + (10000001)原 = (10000010)原 = (-2) 显然不正确。

因为在两个整数的加法运算中是没有问题的,于是就发现问题出现在带符号位的负数身上,对除符号位外的其余各位逐位取反就产生了反码。反码的取值空间和原码相同且一一对应。
下面是反码的减法运算:
(1)10 - (1) 10= (1) 10+ (-1) 10= (0)10
(00000001) 反+ (11111110)反 = (11111111)反 = (-0) 有点小问题。
(1)10 - (2)10 = (1)10 + (-2)10 = (-1)10
(00000001) 反+ (11111101)反 = (11111110)反 = (-1) 正确

问题出现在+0和-0上,在人们的计算概念中零是没有正负之分的。于是就引入了补码概念。 负数的补码就是对反码加一,而正数不变,正数的原码反码补码是一样的。在补码中用(-128)代替了(-0),所以补码的表示范围为:(-128~0~127)共256个。

下面是补码的加减运算:
(1) 10- (1) 10= (1)10 + (-1)10 = (0)10
(00000001)补 + (11111111)补 = (00000000)补 = (0) 正确
(1) 10- (2) 10= (1)10 + (-2)10 = (-1)10
(00000001) 补+ (11111110) 补= (11111111)补 = (-1) 正确

原码、反码、补码都是有符号定点数的表示方法(日常生活中通常都使用有符号数,定点数对应的就是浮点数,即小数),反码、补码是为了简化二进制数的减法运算;
移码常用来比较大小,一般会把浮点数的阶码用移码表示,说的再通俗一点,你把数值用移码表示出来可以一眼看出他们的大小。这样很容易判断阶码的大小,移码可用于简化浮点数的乘除法运算。

功能与目的:

反码:解决负数加法运算问题,将减法运算转换为加法运算,从而简化运算规则;
补码:解决负数加法运算正负零问题,弥补了反码的不足。
总之,反码与补码都是为了解决负数运算问题,跟正数没关系,因此,不管是正整数还是正小数,原码,反码,补码都全部相同。

总结:
1、正数的原码、补码、反码均为其本身;
2、负数(二进制)的原码、补码、反码公式:
反码 = 原码(除符号位外)每位取反
补码 = 反码 + 1
反码 = 补码 - 1
移码 = 补码符号位取反

enpterexpress
enpterexpress   Rxr 2016.01.20 09:37

原码, 反码, 补码 详解
这个讲的不错,值得推荐

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!
其他相关推荐
计算机组成原理 期末复习
<div class="Section1" style="layout-grid:15.6000pt;">计算机组成原理期末复习一、缩写词解释:CPU:中央处理器   ALU:算术逻辑单元   I/O:输入输出接口   RAM:随机存储器  SRAM:静态随机访问存储器  DRAM:动态随机访问存储器   ROM:只读存储器  PROM:用户可编程的只读
为什么带符号的8位二进制数是-128~127啊!而不是-127~127啊!
<br />因为一个带符号数和一个不带符号数一样,8位能表示256个值,如果是-127~127的话,只有255个数!那还少一个。因为7位可以表示128个数,那加上正负肯定能表示256个不同的数。+0的补码就是其原码,也就是说是0000 0000而已(对于8位来说) -0的补码是其反码加1,其反码是1111 1111,当然,其反码加1后就是溢出一个进位后,仍然是0000 0000.所以0和-0的补码都是0000 0000 根据补码原则,0000 0000表示0,而1000 0000却不能表示-0,所以根据
三种机器数,原码,补码,反码
计算机中的数均放在寄存器中,通常称寄存器的位数为机器字长。      无符号数:即没有符号的数,在寄存器中每一位均可用来存放数值。      有符号数:即有符号的数,在寄存器中需要留出相应的位置来存放符号位。          因此,即使寄存器的位数相同,甚至是在同一个寄存器中,所能表示的无符号数和有符号数的数值范围是不同的。对于同一串二进制码来说,看成有符号数,无符号数,原码,补码,正
计算机组成原理 第二章 习题
2-1设机器数的字长为8位(含1为符号位),分别写成下列各二进制数的原码、补码和反码。       0,-0,0.1000,-0.1000,0.1111,-0.1111,1101,-1101 ____________________________________________ 真值             原码         补码             反码 -----------
数的机器码表示(原码,反码,补码,移码)
1. 机器数和真值 二进制数有正负之分,如N1=+0.101101,N2=-0.101101,则N1是个正数,N2是个负数。机器不能直接把符号“+”、“-”表示出来,为了能在计算机中表示正负数,必须引入符号位,即把正负符号也用1位二进制数码来表示。把符号位和数值位一起编码来表示相应的数的表示方法包括:原码、补码、反码、移码等。 为了便于在计算机中表示,同时又便于与实际值相区分,在此首先引入机器
关于有符号位的八位二进制数如何表示-128的原、反、补码的问题
最近学计算机组成原理,遇到一个问题,用有符号八位二进制数表示-128。我看到这个题时一脸懵逼,不是八位二进制数表示的原码和反码范围是-127~128吗?首先,网上的网友,同学以及老师给出了两种说法:    第一种:-128原码和反码不能用八位二进制表示,原因就是-128超出了范围(原码和反码是有+0和-0之分的);但是补码的0没有正负之分,能够表示的范围为-128~128。所以-128的补码表示为...
为什么八位二进制数表示范围为-128~+127?
计算机组成原理、原码、反码、补码、模
让我细细捋一捋原码反码补码以及计算机中负数的表示
弄懂任何问题均需搞清楚来龙去脉,这样大脑才更清晰,问题理解得更透彻! 1.计算机中处理的数据分为数值型数据和非数值型数据两大类 数值型数据是指能进行算术运算(加、减、乘、除四则运算)的数据,即通常所说的具有大小的“数”;非数值型数据是指文字、图像等不能进行算术运算的数据。这里我们重点讨论数值型数据(简称为数值)。数值在计算机内的表示,设计到数值的大小、符号、以及小数点的表示等问题。二进制数只有
8位二进制数能表示的最小整数为什么是-128,10000000为什么是-128的补码。
8位二进制数能表示的最小整数为什么是-128,10000000为什么是-128的补码。http://zhidao.baidu.com/link?url=alT0lvnO6Ac9IFC0qXhnYkPFghLpeoV6R53ePb0DgAvX0AuCF7-2_3OfimTpRgXBM0DWNHN6GN5EIQCGG7iE7_ 2010-12-28 10:50解决问题靠帮助 | 来自手机知道
假设寄存器为8位,用补码形式存储机器数,包括一位符号位,那么十进制数-25在寄存器表示为:
假设寄存器为8位,用补码形式存储机器数,包括一位符号位,那么十进制数-25在寄存器表示为: 正确答案: D   你的答案: 空 (错误) 67H 99H E6H E7H 添加笔记 求解答(6) 收藏 纠错 十进制数-25的原码为10011001,反码为11100110,补码是反码加1,即为11100