当前位置:首页 > 技术实录

通过位运算(不用模运算符%)求余

心智碎片2012-10-04 00:00:00技术实录4650

  模运算 大家都知道就是求余,比如9/8,它的余数就是1,通过9%8可以快捷的求出余数.

  但是这里我为大家介绍一种不通过求模运算符%来求余数的方法.但是他有一个前提,a/b的除数b必必须为2的n次方.也就是说除数b必须是

  2的一次方1

  2的二次方4

  2的三次方8

    ……

    ……

  只有是这样的一种情况,这种方法才是正确的.下来我为大家介绍这种实现,有两种方法.首先为大家介绍一个公式,这是比较好运用的一种.

 

  我们默认除数的8,也就是2的三次方,公式是这样的 a&(8-1)

  现在,我们可以来算一下.默认值a=9,b=8.小括号的内的值为8-1=7.

  9的二进制表现:1001

  7的二进制表现:0111

  9&8的结果值  :0001=1

  也就是说,余数为1,结果是正确的.

  为了证实这个公式的真是可靠,我们可以a=14,继续晕算一次.

  14的二进制表现:1110

  7的二进制表现  :0111

  9&8的结果值    :0110=6

  显而易见,结果也是正确的,大家再缓缓a和b的值来证实一下!

  

  另外一种方式是通过位移运算符来计算.初始值还是a=9,b=8.

  a-((a>>3)<<3)先右移3位,再左移三位,然后a减去移位后的值.

  大家可能要问,为什么是3位呢,因为b是8的,2的3次方是8,所以是移动三位.

 

  好了,两种方式已经介绍清楚了,有什么问题欢迎留言,谢谢!^_^

扫描二维码推送至手机访问。

版权声明:本文由心智碎片发布,如需转载请注明出处。

本文链接:https://diary.mindb.vip/technology/148.html

标签: 百度空间
分享给朋友:

“通过位运算(不用模运算符%)求余” 的相关文章

*.mid转*.mp3——hap_miditomp3.exe

*.mid转*.mp3——hap_miditomp3.exe

今天向大家推荐一款很不错的软件,顾名思义"midtomp3",即可以将mid格式转换为mp3格式。可以说是极品呀,因为mid转mp3格式的软件本来就少,而且这款各方面都很不错,界面简洁、操作简单,大小却还不到1M。界面如下图:…

彩虹(原51挂挂)评测

超大的网盘和方便的网盘操作是最大的优点,而可更改的数字账号在有QQ铺垫的当前社会极具吸引性。…

第一章_第一节_外挂分类

本章节我们介绍当下WG的大致分类,按我目前水平看来,主要分为以下几种:…

Visual C++ 2008 Express Edition下载(微软学生中心官网)

为了防止盗链检测,所以没加跳转,请直接将下列地址复制到“迅雷-新建”。…

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。