取反运算
2017-10-11 18:44
211 查看
网上看到一个人总结的一个公式:~a=-(a+1),我发现是正确的,大家可以随意带入数据进行计算;
具体方法如下:
1,明确数据在内存中的存储方式----------------数据是以补码的方式存在;
2,明确正数和负数的补码求解方式不一样
(1)正数:原码、反码、补码相同
负数:以-18为例
原码:111 1 0010(前3个1为符号位)
反码:(111 0 1101)(前3个1为符号位不变,后面的数取反)
补码:反码+1(111 0 1110)(符号位不变,反码+1)
3,对-18进行求反的方法:补码求反
由于-18是111 0 1110,进行求反为000 1 0001(一定是每一位都取反)
将得到的数转为10进制数,因为符号位是正数,所以原码、反码等都相同,所以取反结果为17
符合公式~a=-(a+1)
具体方法如下:
1,明确数据在内存中的存储方式----------------数据是以补码的方式存在;
2,明确正数和负数的补码求解方式不一样
(1)正数:原码、反码、补码相同
负数:以-18为例
原码:111 1 0010(前3个1为符号位)
反码:(111 0 1101)(前3个1为符号位不变,后面的数取反)
补码:反码+1(111 0 1110)(符号位不变,反码+1)
3,对-18进行求反的方法:补码求反
由于-18是111 0 1110,进行求反为000 1 0001(一定是每一位都取反)
将得到的数转为10进制数,因为符号位是正数,所以原码、反码等都相同,所以取反结果为17
符合公式~a=-(a+1)
相关文章推荐
- 关于取反~的运算
- 位运算取反、求绝对值
- ~ 按位取反运算解析
- c++中按位取反运算
- c++中按位取反运算,类型转换,扩位
- 位运算小结(按位与、按位或、按位异或、取反、左移、右移)
- java中与运算,或运算,异或运算,取反运算
- c++中按位取反运算
- 关于java取反运算
- 定义分数的一目运算+和-,分别代表分数取正和求反,将“按位取反运算符”~重载为分数的求倒数运算。
- 定义分数的一目运算+和-,分别代表分数取正和求反,将“按位取反运算符”~重载为分数的求倒数运算。
- PHP匿点之位运算按位取反
- (数组的应用二:高精度运算4.2.1)POJ 1504 Adding Reversed Numbers(将一个数取反)
- nginx 逻辑运算 if另类嵌套取反匹配等
- 位运算训练03—输入一个整数a,再输入两个整数p1,p2(p1,p2<32);将该整数的二进制表示方法中从右端开始的p1到p2位取反后输出
- 取反运算(~)解法
- C# 取反运算
- 执行"int x=1;int y=~x;"语句后,y的值为?-----取反运算,补码
- java取反运算
- PHP匿点之位运算[与] [或] [异] [取反]