Run ID 作者 问题 语言 测评结果 分数 时间 内存 代码长度 提交时间
105688 林泽豪 高精度减法 C++ 解答错误 0 0 MS 696 KB 892 2023-10-07 14:00:27

Tests(0/30):


#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) //


测评信息: