博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
i/10和i取最后两位的精妙算法(前方高能)
阅读量:6552 次
发布时间:2019-06-24

本文共 337 字,大约阅读时间需要 1 分钟。

i/10;

q2 = (i2 * 52429) >>> (16+3); 52429/524288 = 0.10000038146972656, 524288 = 1 << 19,换句话说q2 = (i2 * 52429) >>> (16+3);就是q2 = i2/10为了避免效率低下的除法

i取最后两位;

r = (int)(i - ((q << 6) + (q << 5) + (q << 2)));很巧妙的使用高效的位移运算完成了r = i - (q * 100),具体实现方式:100 = 64 + 32 + 4,通过位移q再相加,完美实现q * 100。

转载于:https://www.cnblogs.com/langjiaxing/p/8581486.html

你可能感兴趣的文章
ONOS 项目与 Linux 基金会合作开发 SDN/NFV
查看>>
Django高亮Markdown代码
查看>>
第一周
查看>>
Python简介和入门
查看>>
linux常用熟练运用的命令
查看>>
当服务器出现意外时键盘dump
查看>>
java线程池的四种方法测试
查看>>
Mac系统和iphone概述
查看>>
从一个TabBar点击跳转到另一个TabBar(设置)里的页面
查看>>
IT兄弟连 Java Web教程 经典案例2
查看>>
微信分享到朋友圈,怎么自定义分享的标题,图片,内容?
查看>>
PMP-4整合管理
查看>>
mysql 日志
查看>>
php连接mysql
查看>>
salt 001
查看>>
shell文本行截取子串
查看>>
什么是你的核心竞争力之一?
查看>>
MMC卡原理和操作分析
查看>>
MYSQL在一个字段值前面加字符串
查看>>
Linux 端口号划分
查看>>