Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
168653 A班陈旻霄 被限制的加法 C++ 编译错误 0 0 MS 0 KB 945 2024-08-20 12:50:03

Tests(0/0):


#include <bits/stdc++.h> using namespace std; struct big { int l,num[10000]; void read() { string s; cin>>s; l=s.size(); for(int i=0;i<l;i++) num[l-i]=s[i]-'0'; } void print() { for(int i=l;i>=1;i--) cout<<num[i]; } }; big operator+(big a,big b) { big c; c.l=max(a.l,b.l); int t=0; for(int i=1;i<=c.l;i++) { if(i<=a.l) t+=a.num[i]; if(i<=b.l) t+=b.num[i]; c.num[i]=t%10; t/=10; } if(t>0) c.num[++c.l]=t; return c; } big operator*(big a,big b) { big c; c.l=a.l+b.l-1; for(int i=1;i<=a.l;i++) for(int j=1;j<=b.l;j++) c.num[i+j-1]+=a.num[i]*b.num[j]; for(int i=1;i<c.l;i++) { c.num[i+1]+=c.num[i]/10; c.num[i]%=10; } while(c.num[c.l]>=10) { c.num[c.l+1]+=c.num[c.l]/10; c.num[c.l]%=10; c.l++; } return c; } int main() { big a,b; int n; cin>>n; a.l=b.l=n; for(int i=n;i>=1;i--) cin>>a[i]>>b[i]; big c=a+b; c.print(); return 0; }


测评信息: