c++按位取反运算,~9=-10是怎么得到的?
展开全部
比如说这样
int
a
=
1;
那么a
=
1也就是说在二进制里是
0000
0001这样表示的
如果这时这样
a
=
!a;
那么在加上int是有符号的整数所以转换完了a就是这样的
0111
1110
0111
1110
这个表示左边为什么是0你可能不知道因为int是分正数跟负数的。所以要给负数留一位
如果不是不明白加我百度hi
int
a
=
1;
那么a
=
1也就是说在二进制里是
0000
0001这样表示的
如果这时这样
a
=
!a;
那么在加上int是有符号的整数所以转换完了a就是这样的
0111
1110
0111
1110
这个表示左边为什么是0你可能不知道因为int是分正数跟负数的。所以要给负数留一位
如果不是不明白加我百度hi
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
假设整数用16位二进制表示,则
9的原码为:0000000000001001
~9的值为:
1111111111110110
----->这个正好是-10的补码。
9的原码为:0000000000001001
~9的值为:
1111111111110110
----->这个正好是-10的补码。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
计算按位取反的一般方法:
1.
将待计算的数用2进制表示,位数最少为可以表示出当前数的绝对值的二进制位数加1(多1位符号位)。也就是将9表示为01001,其中最左面的0是符号位,0为正,1为负。
2.
将每个二进制位取反,及如果是1,结果为0,反之结果为1。取反后结果为10110
3.
将结果看做是有符号数,转为十进制即可。最左面的一位是符号位,1代表是负的。在计算机中负数是补码表示的,有符号数10110转为10进制即-10
计算按位取反的简便算法
用-1减去待取反的数即为按位取反的结果:-1-9=-10
1.
将待计算的数用2进制表示,位数最少为可以表示出当前数的绝对值的二进制位数加1(多1位符号位)。也就是将9表示为01001,其中最左面的0是符号位,0为正,1为负。
2.
将每个二进制位取反,及如果是1,结果为0,反之结果为1。取反后结果为10110
3.
将结果看做是有符号数,转为十进制即可。最左面的一位是符号位,1代表是负的。在计算机中负数是补码表示的,有符号数10110转为10进制即-10
计算按位取反的简便算法
用-1减去待取反的数即为按位取反的结果:-1-9=-10
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询