2022
我们一起努力

详解跳跃搜索算法

俄式乘法,又被称为俄国农夫法,它是对两个正整数相乘的非主流算法,下面为大家讲解一下俄式乘法算法思想。

详解跳跃搜索算法

假设n和m是两个正整数,计算n*m,现在用n的输入作为实例规模的度量标准。

假设n是偶数,一个规模为原来一半的实例必须要对n/2进行处理,n*m=n/2 * 2m

假设n是奇数,只需要对公式进行简单调整,n*m=(n-1)/2 * 2m

并且使用1*m=m作为终止条件。

我们写下来一个例子就会发现:所有当前n的值是奇数时候,只需要相加对应的m值即可得到n*m的乘积。

例如:5065=25130=12260 (+130)=6520=31040=12080===2080+1040+130=3250

下面我们就开始下代码实现: #includeusing namespace std;

int main(){int n,m,mul=0;cin>>n>>m;for(int i=n>>1;i>=1;i=i>>1){m=mif(i%2==1) { mul=m+mul; } } cout

本文来源:www.lxlinux.net/7241.html,若引用不当,请联系修改。

赞(0)
文章名称:《详解跳跃搜索算法》
文章链接:https://www.fzvps.com/160934.html
本站文章来源于互联网,如有侵权,请联系管理删除,本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
图片版权归属各自创作者所有,图片水印出于防止被无耻之徒盗取劳动成果的目的。

评论 抢沙发

评论前必须登录!