不懂什么是补码——华为面试被毙
听闻某学长被内推到华为面试,结果因为答不上补码是什么而被毙。旷世悲剧啊。让我们来稍微回顾一下下。在计算机系统中,数值用补码来表示(存储)。这样做的好处有很多。计算机采用补码运算非常方便(计算机中数据受字长的限制,数据的运算属于有模运算,并且对运算结果能方便地按模丢掉),而且可使减法运算由加法运算实现。
我们不管补码的标准化定义(始终觉得那是数学家做的事情),直接来看补码的求法。
正数的补码,即是正数的原码;
负数的补码,符号位不变,数值部分取反,然后末位加1.
x=0.100101,
则原=0.100101
故补=0.100101
x=-0.100101,
则原=1.100101(负数原码:符号位为1,数值部分取原数的绝对值)
反=1.011010(负数反码:符号位为1,数值部分按位取反)
故补=1.011011(负数补码:符号位为1,数值部分在反码的基础上末位加1)
页:
[1]