首页 > 其他分享 >信息学一本通 1307:【例1.3】高精度乘法

信息学一本通 1307:【例1.3】高精度乘法

时间:2022-09-03 11:24:25浏览次数:44  
标签:lenc 信息学 1307 高精度 1.3 b1 100 include sizeof

时间限制: 1000 ms         内存限制: 65536 KB

提交数: 47439     通过数: 17996

【题目描述】

输入两个高精度正整数M和N(M和N均小于100位)。求这两个高精度数的积。

【输入】

输入两个高精度正整数M和N。

【输出】

求这两个高精度数的积。

【输入样例】

36
3

【输出样例】

108

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
int main()
{
    char a1[100],b1[100];
    int a[100],b[100],c[100],lena,lenb,lenc,i,j,x;
 
    memset(a,0,sizeof(a));
    memset(b,0,sizeof(b));
    memset(c,0,sizeof(c));
 
    gets(a1);gets(b1);
    lena=strlen(a1);lenb=strlen(b1);
    for(i=0;i<=lena-1;i++) a[lena-i]=a1[i]-'0';
    for(i=0;i<=lenb-1;i++) b[lenb-i]=b1[i]-'0';
    for(i=1;i<=lena;i++)
    {
        x=0;
        for(j=1;j<=lenb;j++)
        {
            c[i+j-1]=a[i]*b[j]+x+c[i+j-1];
            x=c[i+j-1]/10;
            c[i+j-1]%=10;
        }
        c[i+lenb]=x;
    }
    lenc=lena+lenb;
    while(c[lenc]==0&&lenc>1)
        lenc--;
    for(i=lenc;i>=1;i--)
    {
        cout<<c[i];
    }
    return 0;
}

  

标签:lenc,信息学,1307,高精度,1.3,b1,100,include,sizeof
From: https://www.cnblogs.com/sd129/p/16652192.html

相关文章