3115 高精度练习之减法

3115 高精度练习之减法

 

 时间限制: 1 s
 空间限制: 64000 KB
 题目等级 : 黄金 Gold
 
 
 
题目描述 Description

给出两个正整数A和B,计算A-B的值。保证A和B的位数不超过500位。

输入描述 Input Description

读入两个用空格隔开的正整数

输出描述 Output Description

输出A-B的值

样例输入 Sample Input

3 12

样例输出 Sample Output

-9

数据范围及提示 Data Size & Hint

两个正整数的位数不超过500位

分类标签 Tags 

#include<cstdio>
#include<iostream>
#include<cstring>
#define ref(i,x,y)for(int i=x;i<=y;i++)
#define def(i,x,y)for(int i=x;i>=y;i--)
using namespace std;
int lena,lenb,a[1010],b[1010],c[1010];
char a1[1010],b1[1010],n[1010];
int main()
{
    scanf("%s%s",a1,b1);
    if((strlen(a1)<strlen(b1))||(strlen(a1)==strlen(b1)&&strcmp(a1,b1)<0)){
        strcpy(n,a1);
        strcpy(a1,b1);
        strcpy(b1,n);
        printf("-");
    }
    lena=strlen(a1);lenb=strlen(b1);
    ref(i,0,lena-1) a[lena-i]=a1[i]-48;
    ref(i,0,lenb-1) b[lenb-i]=b1[i]-48;
    ref(i,1,lena){
        if(a[i]<b[i]){
            a[i+1]--;a[i]+=10;
        }
        c[i]=a[i]-b[i];
    }
    int j=lena+1;
    while(c[j]==0&&j>1) j--;
    def(i,j,1) printf("%d",c[i]);
    return 0;
}
原文地址:https://www.cnblogs.com/shenben/p/5558843.html