左移右移1位是否一定等价于乘2除2?

有个疑问,平常我们都爱说用移位代替乘除法来提高性能,那么是不是任何地方都能用移位代替乘除法呢?下面这个例子是不是说明不是所有地方都能用移位替代乘除法?比如下面最后 b = -1 时右移 1 位还是-1,和直观理解除以 2 得到 0 不等价。

int a = 2;
//得到 1
a = a >> 1;
//得到 0
a = a >> 1;

int b = -2;
//得到 -1
b = b >> 1;
//期望得到 0,实际得到 -1,
b = b >> 1;
#笔试题目#
全部评论
我也想知道答案
点赞 回复 分享
发布于 2019-07-01 15:19
无符号数才能用右移代替除2啊  
点赞 回复 分享
发布于 2019-07-01 15:26
因为-2在计算机是表示成补码的,-2的补码是1110(相对于四位存储),你这应该是带符号右移就是(1111),就成了-1
点赞 回复 分享
发布于 2019-07-01 15:39
无符号是
点赞 回复 分享
发布于 2019-07-01 15:42
二进制左移右移去看看原理吧。。。
点赞 回复 分享
发布于 2019-07-01 17:08
是的,只有无符号整数右移才能像除法一样,因为c/c++除法是向0取整,而右移是向下取整 左移和乘法完全一致
点赞 回复 分享
发布于 2023-11-08 13:52 广东

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务