- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我了解二进制的工作原理,可以计算二进制到十进制,但是我迷失在带符号的数字周围。
我已经找到了执行转换的calculator。但是我不确定如何找到最大和最小的数字,或者如果没有给出二进制数字,如何转换,而StackO中的问题似乎是关于转换特定数字或不包括带符号数字到特定位的问题。
具体问题是:
We have only 5 bits for representing signed numbers in two's complement:
What is the highest signed integer?
Write its decimal value (including the sign only if negative).
What is the lowest signed integer?
Write its decimal value (including the sign only if negative).
最佳答案
从逻辑角度来看:
签名中的界限
您有5位,因此有32种不同的组合。这意味着您可以用5位输入32个不同的数字。对于无符号整数,在5位上存储0到31(含)之间的整数是有意义的。
但是,这是关于无符号整数。含义:我们还必须找到一种表示负数的方法。含义:我们必须存储数字的值,还必须存储其符号(+或-)。所使用的表示形式是2的补数,并且是到处都可以学习的表示形式(也许其他存在,但我不知道)。在此表示形式中,符号由第一位给出。也就是说,在2的补码表示中,正数以0开头,负数以1开头。
问题就出现了:0是正数还是负数?不能两者都用,因为这意味着对于给定的数字a位(对于5:00000和10000),可以用两种方式表示0,即我们失去了再放置一个数字的空间。我不知道他们是如何决定的,但事实是0是一个正数。对于带符号或无符号的任何位数,仅用0表示0。
大。这为我们提供了第一个问题的答案:以2的补码表示的十进制数的上限是多少?我们知道第一位是符号,因此我们可以表示的所有数字必须由4位组成。我们可以有16个不同的4位字符串值,0是其中之一,因此上限是15。
现在,对于负数,这变得容易。我们已经在5位上可以填充的32个值中填充了16个值。还剩16个。我们也知道0已经被表示了,所以我们不需要包含它。然后,我们从0:-1之前的数字开始。因为我们有16个数字表示,从-1开始,所以可以在5位上表示的最低带符号整数是-16。
更一般而言,使用n
位可以表示2^n
数字。对于带符号整数,其中一半为正,一半为负。也就是说,我们有2^(n-1)
个正数和2^(n-1)
个负数。我们知道0被认为是正数,在n
位上可以表示的最大有符号整数是2^(n-1) - 1
,而最小的是-2^(n-1)
2的补码表示
既然我们知道哪些数字可以用5位表示,那么问题是要知道我们如何表示它们。
我们已经看到符号显示在第一位,并且0被认为是正数。对于正数,其工作方式与处理无符号整数相同:00000为0,00001为1,00010为2,依此类推,直到01111为15。这是我们停止使用正号整数的原因,因为我们已经占用了所有我们拥有16个值。
对于带负号的整数,这是不同的。如果我们保持相同的表示形式(10001是-1,10010是-2,...),那么我们最终会得到11111为-15和10000未归因。我们可以决定说它是-16,但是每次使用负整数时,我们都必须检查这种特殊情况。另外,这搞乱了所有二进制操作。我们还可以决定10000是-1,10001是-2,10010是-3,依此类推。但是它也弄乱了所有二进制运算。
2的补码按以下方式工作。假设您有一个带符号的整数10011,想知道十进制是什么。
翻转所有位:10011-> 01100
添加1:01100-> 01101
将其读取为无符号整数:01101 = 0 * 2 ^ 4 + 1 * 2 ^ 3 + 1 * 2 ^ 2 + 0 * 2 ^ 1 + 1 * 2 ^ 0 = 13。
10011表示-13。这种表示非常方便,因为它可以双向工作。如何将-7表示为二进制有符号整数?从7的二进制表示形式(00111)开始。
翻转所有位:00111-> 11000
添加1:11000-> 11001
就是这样!在5位上,-7用11001表示。
我不会介绍它,但是2的补码的另一个巨大优点是加法的工作方式相同。也就是说,在添加两个二进制数字时,您不必关心它们是否是有符号的或无符号的,这就是后面的相同算法。
这样,您应该能够回答问题,但更重要的是理解答案。
本主题非常适合理解2的补码:Why is two's complement used to represent negative numbers?
关于math - 5位二进制补码中代表有符号数的最高和最低整数是多少?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37274102/
我正在尝试学习 Fortran,并且看到了很多不同的定义,我想知道他们是否正在尝试完成同样的事情。以下有什么区别? 整数*4 整数(4) 整数(kind=4) 最佳答案 在 Fortran >=90
我以前从未编程过,最近(1 周前)才开始学习!第一门类(class)是函数式编程,使用 Haskell。 我有一项学校作业,我想通过删除一两个步骤来改进它,但我遇到了一个讨厌的错误。 基本上,我创建了
给定以下GraphQL请求和变量: 请求: query accounts($filter:AccountFilter, $first_:String, $skip_:Int) { accounts
我已经搜索了 StackOverflow,但找不到关于如何检查计算器应用程序的数字输入正则表达式的答案,该计算器应用程序将检查每个 keyup 的以下格式(jquery key up): 任何整数,例
类似于我上一篇致歉的文章,但没有那么长篇大论。基本上我想知道当每次重绘调用只重绘屏幕的一小部分时,优化重绘到 JFrame/JPanel 的最佳选择是什么。 此外,除了重绘重载之外,我并不是 100%
所以在我的教科书中有一个使用 f# 的递归函数的例子 let rec gcd = function | (0,n) -> n | (m,n) -> gcd(n % m,m);; 使用此功能,我的教科书
我有一个数据结构,例如表达式树或图形。我想添加一些“测量”功能,例如depth和 size . 如何最好地键入这些函数? 我认为以下三个变体的用处大致相同: depth :: Expr -> Int
这样写比较好 int primitive1 = 3, primitive2 = 4; Integer a = new Integer(primitive1); Integer b = new Inte
我是 Java 8 新手,想根据键对 Map 进行排序,然后在值内对每个列表进行排序。 我试图寻找一种 Java 8 方法来对键和值进行排序。HashMap>映射 map.entrySet().str
这就是我的目标... vector ,int> > var_name (x, pair (y),int>); 其中 x 是 vector var_name 的大小,y 是对内 vector 的大小。
这里是 an answer to "How do I instantiate a Queue object in java?" , Queue is an interface. You can't i
这个问题在这里已经有了答案: Weird Integer boxing in Java (12 个答案) Why are autoboxed Integers and .getClass() val
我们可以使用 C++ STL 做这样的事情吗?如果是,我将如何初始化元素?我试图这样做,但没有成功。 pair,vector>p; p.first[0]=2; 最佳答案 Can we do som
您好,我正在尝试为百分比和整数数组中的数字找到索引。假设 arraynum = ['10%','250','20%','500'] 并且用户发送一个值 15%,这个数字在哪个范围内居住?我可以使用这段
我与三列有关系:ProductName、CategoryID 和 Price。我需要选择仅那些价格高于给定类别中平均产品价格的产品。(例如,当apple(ProductName)是fruit(Cate
我已经坚持了一段时间,我正在尝试将一些数据配对在一起。这是我的代码。 #include #include using namespace std; int main() { pair data(
我收到错误:'(Int, Int)' 与 'CGPoint' 不相同 如何将 (Int, Int) 转换为 CGPoint let zigzag = [(100,100), (100,150)
我在 .cpp 文件中发现了以下代码。我不理解涉及头文件的构造或语法。我确实认识到这些特定的头文件与 Android NDK 相关。但是,我认为这个问题是关于 C++ 语法的一般问题。这些在某种程度上
我将这些输入到 Scala 解释器中: val a : Integer = 1; val b : Integer = a + 1; 我收到消息: :5: error: type mismatch;
C++:vector>v(size);当我试图打印出值时显示 0 作为值,但是当未声明 vector 大小时它显示正确的输出?为什么这样?例如: int x; cin>>x; vector>v(x);
我是一名优秀的程序员,十分优秀!