阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

算法——俄式乘法

32次阅读
没有评论

共计 419 个字符,预计需要花费 2 分钟才能阅读完成。

两个正整数相乘的非主流算法

假设 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 的乘积。

例如:50*65=25*130=12*260(+130)=6*520=3*1040=1*2080===2080+1040+130=3250

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

int main()
{
int n,m,mul=0;
cin>>n>>m;
for(int i=n>>1;i>=1;i=i>>1)
{
m=m

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计419字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中