二进制的数移位问题
1.#include<stdio.h>
void main()
{
int a = 20, b;
for (int i = 1; i <= 3; i++)
{
b = a >> i;
printf("%d>>%d位后为:%d\n", a, i, b);
}
}
**********************************************************************************
20>>1位后为:10
20>>2位后为:5
20>>3位后为:2
C:\Users\lenovo\Desktop\Project1\x64\Debug\Project1.exe (进程 27476)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .
************************************************************************************
这个是正常的,有正常的进度损失
2.
#include<stdio.h>
void main()
{
int a = 20, b;
for (int i = 1; i <= 3; i++)
{
b = a >> i;
printf("%d>>%d位后为:%d\n", a, i, b);
}
}
********************************************************************************
-20>>1位后为:-10
-20>>2位后为:-5
-20>>3位后为:-3
C:\Users\lenovo\Desktop\Project1\x64\Debug\Project1.exe (进程 30252)已退出,代码为 0。
要在调试停止时自动关闭控制台,请启用“工具”->“选项”->“调试”->“调试停止时自动关闭控制台”。
按任意键关闭此窗口. . .
*********************************************************************************
这个就是多了个负号-20右移3为就不是-2了额
按理来说:原码 : 1001 0100.
右移3为后: 1000 0010.100(舍弃)即:1000 0010 =-2;
-5 /2 = -2.5 取最小的,因为-3<-2,所以取-3 临时号 发表于 2022-6-18 23:33
-5 /2 = -2.5 取最小的,因为-3
额,为啥-5/2这个原理不是进行移位操作吗,变相的“/2”,我刚学计算机组成原理,按上面内种讲法,就是会造成精度损失,您说的我没听懂 临时号 发表于 2022-6-18 23:33
-5 /2 = -2.5 取最小的,因为-3
右移3为后: 1000 0010.100(舍弃)即:1000 0010 =-2;
我这一步有啥毛病吗呜呜
她与晚风 发表于 2022-6-18 23:37
额,为啥-5/2这个原理不是进行移位操作吗,变相的“/2”,我刚学计算机组成原理,按上面内种讲法,就是会 ...
20 0001 0100 进行求补运算 取反1110 1011 +1后 1110 1100 这就是-20的二进制
-20>>3 算术右移3位 1111 1101 变成这个 也就是-3 对应的二进制了
因为是负数,左边第一位是1,所以算术右移3位相当于左边加 3个 1,右边再减去3位 .
至于取最小值那是我记忆的方法 临时号 发表于 2022-6-18 23:42
20 0001 0100 进行求补运算 取反1110 1011 +1后 1110 1100 这就是-20的二进制
-20>>3 算术右移3位 1111...
啊这个1110 1100是-20的补码吧,您这个是用补码移位然后在转化过来吗还是怎么的,我没学到这里了
我这个原码直接移动有啥毛病呀
页:
[1]