Run ID | 作者 | 问题 | 语言 | 测评结果 | 分数 | 时间 | 内存 | 代码长度 | 提交时间 |
---|---|---|---|---|---|---|---|---|---|
105538 | 林泽豪 | 高精度减法 | C++ | 解答错误 | 90 | 0 MS | 280 KB | 788 | 2023-10-07 13:17:56 |
#include<cstdio> #include<iostream> #include<cstdio> #include<bits/stdc++.h> using namespace std; int a1[5005],b1[5005],c[5005],m; int main() { char a[6000],b[6000]; cin>>a>>b; if(strlen(a)<strlen(b)||strlen(a)==strlen(b)&&a[0]>b[0]){ swap(a,b); cout<<'-'; } 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]; if(c[lenc]<0){ c[lenc]+=10; a1[lenc+1]--; } lenc++; } c[lenc]=x; while(c[lenc]==0&&lenc>1){ lenc--; } for(int i=lenc;i>=1;i--){ cout<<c[i]; } return 0; }