最有效率的方法算出2乘以8等於几?

在java语言中,出学java,望名人指点... 在java语言中,出学java,望名人指点 展开
 我来答
wffyfx
推荐于2019-11-05 · TA获得超过1.3万个赞
知道答主
回答量:42
采纳率:87%
帮助的人:5.4万
展开全部

这道题的解法:
2<<3; 表示 2向左移 3位:2 * 2^3(2的3次方) = 2 * 8;

因为一个数左移 n位,就相当于 2的 n次方,那么一个数乘以 8只要将其左移 3位即可,而为运算符的效率最高,所以 2乘以 8等于几的最有效方法是 2<<3。

扩展资料:

左移运算符:

用来将一个数的各二进制位全部左移若干位。因为位运算比×运算快,所以可对以下代码进行优化,还可利用左移运算符计算a的第b个二进制位是什么。

运算规则:

按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。

语法格式:

需要移位的数字 << 移位的次数

例如: 3 << 2,则是将数字3左移2位

计算过程:

3 << 2 首先把3转换为二进制数字0000 0011,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 1100,则转换为十进制是12。

数学意义:

在数字没有溢出的前提下,对于正数和负数,左移一位都相当于乘以2的1次方,左移n位就相当于乘以2的n次方。

大雅新科技有限公司
2024-11-19 广告
这方面更多更全面的信息其实可以找下大雅新。深圳市大雅新科技有限公司从事KVM延长器,DVI延长器,USB延长器,键盘鼠标延长器,双绞线视频传输器,VGA视频双绞线传输器,VGA延长器,VGA视频延长器,DVI KVM 切换器等,优质供应商,... 点击进入详情页
本回答由大雅新科技有限公司提供
末你要
高粉答主

推荐于2019-10-21 · 说的都是干货,快来关注
知道小有建树答主
回答量:380
采纳率:100%
帮助的人:11.3万
展开全部

这道题最有效率的解法如下:

2<<3; 表示2 向左移 3位:2 * 2^3(2的3次方) = 2 * 8;

在这道题中,因为一个数左移 n位,就相当于 2的 n次方,那么一个数乘以 8只要将其左移 3位即可,而为运算符的效率最高,所以 2乘以 8等于几的最有效方法是 2<<3。

扩展资料:

语法格式:

需要移位的数字 << 移位的次数

例如: 3 << 2,则是将数字3左移2位

计算过程:

3 << 2 首先把3转换为二进制数字0000 0011,然后把该数字高位(左侧)的两个零移出,其他的数字都朝左平移2位,最后在低位(右侧)的两个空位补零。则得到的最终结果是0000 1100,则转换为十进制是12。

它的运算规则就是按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
河传杨颖
高粉答主

推荐于2019-10-22 · 说的都是干货,快来关注
知道小有建树答主
回答量:745
采纳率:100%
帮助的人:20万
展开全部

这道题的解法:

2<<3; 表示 2向左移 3位:2 * 2^3(2的3次方) = 2 * 8;

因为一个数左移 n位,就相当于 2的 n次方,那么一个数乘以 8只要将其左移 3位即可,而为运算符的效率最高,所以 2乘以 8等于几的最有效方法是 2<<3。

扩展资料

左移运算符:

用来将一个数的各二进制位全部左移若干位。因为位运算比×运算快,所以可对以下代码进行优化,还可利用左移运算符计算a的第b个二进制位是什么。

运算规则:

按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零。

背诵乘法口诀,可以通过理解记忆来识记背诵。理解性记忆需要有一定的参照物,即自己比较熟悉的口诀。

例如:二五一十、九九八十一等,将这些口诀作为参照物,可运用推算的方法很快找到与之相邻的乘法口诀。

8×9的结果想不出,则可思考“9个9减去一个9”,也就是“81-9=72”,当然得出结论后不能写上72就算了,还应把“8×9”的口诀在心里默念一遍,那么多经历几次这样的思考后,“八九七十二”这句也将成为铭记于心的口诀了。

本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
招海散此牵1T
推荐于2017-05-15 · TA获得超过939个赞
知道小有建树答主
回答量:601
采纳率:0%
帮助的人:0
展开全部
引用mm3345177的回答:
用移位运算 int a=2<<3;
a就是2乘以8 最后结果是16 这是最省内存 最有效率的方法

这个方法确实高效率的。我来解释一下:
2的二进制是10 在32位存储器里面是0000 0000 0000 0010
左移三位后变成 0000 0000 0001 0000 也就是16

再来观察左移三位,需要消耗3个机器时钟,如果能在一个时钟内完成,效率就更高了。
a=2 & 16 只要一个机器时钟。^_^,效率是不是更高呢?

其实这个问题没有多大的实际意义,不过方法是可以借鉴的,既然楼主提出来了,就当讨论讨论咯。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
雨橘鱼3860
2006-04-20 · 超过10用户采纳过TA的回答
知道答主
回答量:114
采纳率:0%
帮助的人:23.3万
展开全部
用移位运算 int a=2<<3;
a就是2乘以8 最后结果是16 这是最省内存 最有效率的方法
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(9)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式