社区讨论

求助!(怀疑数据)

P2142高精度减法参与者 5已保存回复 6

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
6 条
当前快照
1 份
快照标识符
@mi6hknk6
此快照首次捕获于
2025/11/20 05:00
4 个月前
此快照最后确认于
2025/11/20 05:00
4 个月前
查看原帖
下了第一个数据点,正确的。也拿拍过标程了,然而0分,全WA
CPP
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
using namespace std;
int main()
{
    //freopen("123.in","r",stdin);
    //freopen("123.out","w",stdout);
    char n1[30000],n2[30000],n[3000];
    int lena,lenb,lenc,a[3000],b[3000],c[3000];
    gets(n1);
    gets(n2);
    if(strlen(n1)<strlen(n2)||(strlen(n1)==strlen(n2)&&strcmp(n1,n2)<0))
    {
        strcpy(n,n1);
        strcpy(n1,n2);
        strcpy(n2,n);
        cout<<"-";
    }
    lena=strlen(n1);
    lenb=strlen(n2);
    for(int i=lena-1,j=0;i>=0;i--,j++) a[j]=int(n1[i]-'0');
    for(int i=lenb-1,j=0;i>=0;i--,j++) b[j]=int(n2[i]-'0');
    int i=0;
    while(i<lena||i<lenb)
    {
        if(a[i]<b[i])
        {
            a[i]+=10;
            a[i+1]--;
        }
        c[i++]=a[i]-b[i];
    }
    lenc=i-1;
    while(c[lenc]==0&&lenc>1)
    lenc--;
    for(int j=lenc;j>=0;j--)
    cout<<c[j];
    return 0;
}

回复

6 条回复,欢迎继续交流。

正在加载回复...