• 补码与整型的转换


    转自:https://blog.csdn.net/weixin_43661242/article/details/85031263

    https://blog.csdn.net/weixin_45447985/article/details/104328051

    1.补码

    8位二进制表示的范围:-2^7~2^7-1。

    具体编码的规律如下:

    编码00000000代表的整数是0
    编码00000001代表的整数是1
    编码00000010代表的整数是2
    ……
    编码01111111代表的整数是127
    编码10000000代表的整数是-128(而不是128)
    编码10000001代表的整数是-127(而不是129)
    编码10000010代表的整数是-126(而不是130)

    2.补码转换为整数

    #include<bits/stdc++.h>
    using namespace std;
    typedef long long ll;
    int main(){
       string s;
       cin>>s;
       ll ans=0;
       for(ll i=0;i<s.size();i++) ans=ans*2+s[i]-'0';
       if(ans>=128) ans-=256;
       cout<<ans;
        return 0;
    }

    补码的符号位是参与运算的,原码和反码的符号位不参与运算。

    定点整数:
    x的补码=10011;x的真值等于1*1+1*2+0*4+0*8+(-1)*16=-13
    转换为原码验证一下,x的原码=11101,即-(1
    1+02+14+1*8)=-13
    所以,在定点整数中,补码转换为真值即可将符号位带入运算,但是权值要根据符号位的具体表示含义做出更改。

    所以在上述转换代码中,直接判断是否超过最大表示,若超过了那么直接将符号位减去即可表示对应的负数。

  • 相关阅读:
    T-SQL 查询数据库中各个表的使用空间
    T-SQL 拆分使用指定分隔符的字符串(split string)
    T-SQL 去除特定字段的前导0
    T-SQL 实现行转列
    T-SQL 将存储过程结果插入到表中
    T-SQL查看数据库恢复(RESTORE)时间
    Why Do We Need a Data Warehouse?
    T-SQL 常用DDL语句
    dedecms织梦笔记
    Lua 基础简明教程
  • 原文地址:https://www.cnblogs.com/BlueBlueSea/p/15383147.html
Copyright © 2020-2023  润新知