Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
105688 | 林泽豪 | 高精度减法 | C++ | 解答错误 | 0 | 0 MS | 696 KB | 892 | 2023-10-07 14:00:27 |
#include<cstdio> #include<iostream> #include<cstdio> #include<bits/stdc++.h> using namespace std; int a1[5005],b1[5005],c[26005],m=0; int main() { char a[6000],b[6000]; cin>>a>>b; int lena=strlen(a); int lenb=strlen(b); for(int i=1;i<=lena;i++){ a1[i]=a[lena-i]-'0'; } for(int i=1;i<=lenb;i++){ b1[i]=b[lenb-i]-'0'; } int lenc=1; //int x=0; int x[26000]; for(int i=1;i<=lena;i++){ for(int o=1;o<=lenb;o++){ c[i*o]+=a1[i]*b1[o]+x[i*o+1]; if(c[i*o]>=10){ x[i*o+1]=c[i+o]/10; c[i*o]%=10; } } } lenc=lena*lenb; c[lenc+1]=x[lenc+1]; while(c[lenc+1]==0&&lenc>1){ lenc--; } for(int i=lenc+1;i>=1;i--){ cout<<c[i]; } return 0; } // 222 //* 9 //_______ // 2*9*10^(1+1) // 2*9*10^(1+2) // 2*9*10^(1+3) //