补码与整型的转换
转换 整型 补码
2023-09-14 09:11:20 时间
转自: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,即-(11+02+14+1*8)=-13
所以,在定点整数中,补码转换为真值即可将符号位带入运算,但是权值要根据符号位的具体表示含义做出更改。
所以在上述转换代码中,直接判断是否超过最大表示,若超过了那么直接将符号位减去即可表示对应的负数。
相关文章
- python轻松实现代码编码格式转换
- XmlDocument,XDocument相互转换
- windows程序设计(五)---映射模式(转换设备坐标和逻辑坐标)
- 【转】Cvmat与IplImage的相互转换
- Atitit.jsou html转换纯文本 java c# php
- atitit.XML类库选型及object 对象bean 跟json转换方案
- Atitit.js javascript异常处理机制与java异常的转换 多重catc hDWR 环境 .js exception process Vob7
- ffplay源码分析:图像格式转换
- Java中Date与 LocalDateTime ,LocalDate之间的转换
- 练习2-3 编写函数 htoi(s),把由十六进制数字组成的字符串(包含可选的前缀0x 或0X)转换为与之等价的整型值。字符串中允许包含的数字包括:0~9、a~f以及A~F。
- OpenLayers学习笔记2——坐标转换问题
- VL33-非整数倍数据位宽转换8to12,实现先到的数据应置于输出的 高bit 位。
- VC++图片类型之间的相互转换(附源码)
- JavaScript基础(一)js环境搭建、变量常量、数据类型及转换、运算符