进阶41 部落人乘法

41 部落人乘法

作者: 朱星垠 时间限制: 10S章节: 一维数组

问题描述 :

明明热爱数学,他的爸爸也有意培养明明对数学的兴趣。

一次,为了拓展明明的知识面,爸爸给明明讲了一个原始部落人计算乘法的方法:

据说原始部落人以小石子作为计算工具,并用减半和加倍两种运算就能求得任何两个整数的乘积。

其规则是:

左边不断除2,写下商,舍去余数;

右边不断加倍,直到左边变成1为止。

取结果的方法是:

如果某行左边是偶数,就划去整个这一行;

如果某行左边是奇数,右边剩下的数相加即可。

例如求13与15的乘积的过程是:

计算过程:

13--------15 :13除以2等于6,舍去余数1,15乘以2等于30;

6---------30 :6除以2等于3,30乘以2等于60;

3---------60 :3除以2等于1,舍去余数1,60乘以2等于120;

1---------120 :左边数字为1,停止计算。

取结果过程:

13--------15 :左边是奇数,取15;

6---------30 :左边是偶数,划去;

3---------60 :取60;

1---------120 :取120;

其结果就是: 13*15=15+60+120=195。

明明对爸爸讲的这个故事相当感兴趣,也自己动手开始模拟上面的过程计算起来。刚开始的时候,明明感觉这样计算很有趣,但是时间一长,明明就觉得这样的计算过程很麻烦。他想让你帮他写一个程序,快速的计算出上述乘法最后相加的式子和结果。

明明的问题可以归结为:给你两个整数,使用上面描述的乘法过程,输出最后的相加的式子。

输入说明 :

你的程序需要从标准输入设备(通常为键盘)中读入多组测试数据。每组测试数据占一行,其中包含两个整数a和b(1 <= a, b <= 100)。

输出说明 :

对每组测试数据,你的程序需要向标准输出设备(通常为启动该程序的终端)依次输出一组对应的答案。格式参见样例。

输入范例 :
13 15
2 4
输出范例 :
1315=15+60+120=195
2
4=8=8

#include<stdio.h>
int main(){
	int m,n,a[200],b[200],i,j,k,p,sum;
	while(scanf("%d%d",&m,&n)!=EOF){
       i=1;
	   p=m;
	   if(m!=1){
		   a[i++]=p;
		   a[i++]=n;
		   while((p/2)!=1){
			   a[i++]=p/2;
			   p=p/2;
			   a[i++]=a[i-3]*2;
		   }
		   a[i]=1;
		   a[i+1]=a[i-1]*2;
	   }else{
		   a[i]=m;
		   a[i+1]=n;
	   }
	   k=1;
	   for(j=1;j<=i;j++)
		   if(j%2!=0&&a[j]%2!=0)  b[k++]=a[j+1];
	   printf("%d*%d=",m,n);
	   sum=0;
	   for(j=1;j<k;j++){
           sum+=b[j];
		   if(j==k-1) printf("%d",b[j]);
           else printf("%d+",b[j]);
	   }
	   printf("=%d",sum);
     printf("\n");
	}
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值