Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
105538 林泽豪 高精度减法 C++ 解答错误 90 0 MS 280 KB 788 2023-10-07 13:17:56

Tests(27/30):


#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; }


测评信息: