她与晚风 发表于 2022-6-18 23:27:23

二进制的数移位问题

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;

临时号 发表于 2022-6-18 23:33:49

-5 /2 = -2.5 取最小的,因为-3<-2,所以取-3

她与晚风 发表于 2022-6-18 23:37:34

临时号 发表于 2022-6-18 23:33
-5 /2 = -2.5 取最小的,因为-3

额,为啥-5/2这个原理不是进行移位操作吗,变相的“/2”,我刚学计算机组成原理,按上面内种讲法,就是会造成精度损失,您说的我没听懂

她与晚风 发表于 2022-6-18 23:38:38

临时号 发表于 2022-6-18 23:33
-5 /2 = -2.5 取最小的,因为-3

右移3为后:   1000 0010.100(舍弃)即:1000 0010    =-2;
我这一步有啥毛病吗呜呜

临时号 发表于 2022-6-18 23:42:07

她与晚风 发表于 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:50:59

临时号 发表于 2022-6-18 23:42
20 0001 0100 进行求补运算 取反1110 1011 +1后 1110 1100 这就是-20的二进制
-20>>3 算术右移3位 1111...

啊这个1110 1100是-20的补码吧,您这个是用补码移位然后在转化过来吗还是怎么的,我没学到这里了

我这个原码直接移动有啥毛病呀
页: [1]
查看完整版本: 二进制的数移位问题