zoukankan      html  css  js  c++  java
  • 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;
    }
  • 相关阅读:
    使用 star UML制作的图
    评价片段
    项目部分
    用新学的知识 写了一段小代码
    常用系统存储过程
    考试小总结
    分页
    行转列面试题 事例
    子查询
    生成验证码的方法集合(一)
  • 原文地址:https://www.cnblogs.com/shenben/p/5558843.html
Copyright © 2011-2022 走看看