1307:【例1.3】高精度乘法

偶尔善良 提交于 2020-01-24 17:21:12

1307:【例1.3】高精度乘法
时间限制: 1000 ms         内存限制: 65536 KB
【题目描述】
输入两个高精度正整数M和N(M和N均小于100位)。求这两个高精度数的积。
【输入】
输入两个高精度正整数M和N。
【输出】
求这两个高精度数的积。
【输入样例】
36
3
【输出样例】
108
【来源】

#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
int main()
{
	char ach[101],bch[101];
	int a[101],b[101],c[10001],lena,lenb,lenc,i,j,jw;
	memset(a,0,sizeof(a));
	memset(b,0,sizeof(b));
	memset(c,0,sizeof(c));
	scanf("%s",ach);
	scanf("%s",bch);
	lena=strlen(ach),lenb=strlen(bch);
	for(i=0;i<lena;i++) a[lena-i]=ach[i]-'0';
	for(i=0;i<lenb;i++) b[lenb-i]=bch[i]-'0';
	for(i=1;i<=lena;i++){
		jw=0;
		for(j=1;j<=lenb;j++){
			c[i+j-1]=a[i]*b[j]+jw+c[i+j-1];
			jw=c[i+j-1]/10;
			c[i+j-1]%=10;
		}
		c[i+lenb]=jw;	
	}
	lenc=lena+lenb;
	while(c[lenc]==0&&lenc>1) lenc--;
	for(i=lenc;i>0;i--) printf("%d",c[i]);
	printf("\n");
	return 0;
 } 


No

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!