zoukankan      html  css  js  c++  java
  • abs(INT_MIN) = ?

    abs(INT_MIN) = INT_MIN

    为什么?

    因为INT_MIN = 1000 0000B

    对INT_MIN取反再加一仍然是1000 0000B

    (1)为什么求一个数的负数是取反再加一?

    8 = 0000 1000B

    -8 = 0 - 8 = 0000 0000B - 0000 1000B

    因为减法有借位性质,所以上式等同于:

    1 0000 0000B - 0000 1000B = 1111 1000B

    又因为1 0000 0000B = 1111 1111B + 0000 0001B

    所以1 0000 0000B - 0000 1000B = 1111 1111B - 0000 1000B + 0000 0001B

    而被1111 1111B减等同于求反

    所以求一个数的负数等同于求反再加一

    (2)补码的本质数互为补数

    假设模为100, a+b = 100,则a和b互为补数

    二进制中,对于8位数,1 0000 0000B可以看作他们的模,这样1111 1111 和 0000 0001互为补数,人们约定前者代表-1后者代表1

    就像模为100时,50的补数是他自己,只有一种表示,只能代表一个数字

    模为1 0000 0000B时,1000 0000B也和自己互补,按照之前的约定,最大的正数是0111 1111B = 127,-127 = 1000 0001B

    所以1000 0000B就被约定为-128

    (3)为什么不把1000 000B约定为128

    1000 000B+000 0001B = 1000 0001B = -128 + 1 = -127

    刚好符合之前的约定,如果是128则式子代表128 + 1 = -127,这样的式子不合理

    参考资料:

    https://www.douban.com/note/223507364/

  • 相关阅读:
    使用phpize安装php模块
    centos如何卸载软件
    修改centos环境变量
    linux系统安装php扩展
    php单入口session处理
    session阻塞机制,解决方法
    uploadify插件的使用
    php图片上传代码
    validate插件的使用
    datepicker使用
  • 原文地址:https://www.cnblogs.com/N3ptuner/p/12625382.html
Copyright © 2011-2022 走看看