Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
105507 | 林泽豪 | 高精度加法 | C++ | 通过 | 100 | 0 MS | 272 KB | 663 | 2023-10-07 13:01:16 |
#include<cstdio> #include<iostream> #include<cstdio> #include<bits/stdc++.h> using namespace std; int a1[5005],b1[5005],c[5005]; int main() { char a[6000],b[5200]; 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; while(lenc<=lena||lenc<=lenb){ c[lenc]=a1[lenc]+b1[lenc]+x; x=c[lenc]/10; c[lenc]%=10; lenc++; } c[lenc]=x; while(c[lenc]==0&&lenc>1){ lenc--; } for(int i=lenc;i>=1;i--){ cout<<c[i]; } return 0; }