3115 高精度练习之减法
Posted 神犇(shenben)
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了3115 高精度练习之减法相关的知识,希望对你有一定的参考价值。
题目描述 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; }
以上是关于3115 高精度练习之减法的主要内容,如果未能解决你的问题,请参考以下文章