i/10和i取最后两位的精妙算法(前方高能)

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