2 luky1117 luky1117 于 2013.11.20 12:01 提问

一个32bit的数除以520怎么用C实现效率最高?

一个32bit的数除以520怎么用C实现效率最高?还有
一个32bit的数乘以520怎么用C实现效率最高?

3个回答

jinqmao
jinqmao   2013.12.04 15:51
已采纳

设定初始值为A,结果为X
除:X=A>>9-(A-(A>>6)<>3
也就是A右移9位,减去((A-A右移6位再左移6位)右移3位);
乘:X=A<<9+A<<3
也就是左移9位,加上左移3位(乘的意义不大,本来就可以拆分的)

fylsle
fylsle   2013.11.27 10:22

这个问题比较高深啊。。。

a1193561652
a1193561652   Rxr 2015.05.22 13:25

可以内嵌汇编,除法用div指令,乘法是mul指令,这应该算效率很高了吧。

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!