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;
    }
  • 相关阅读:
    DBA 职责及日常工作职责
    mysql 语句笔记
    学习Groovy — 闭包
    linux 命令: 网络和进程
    linux命令: rm命令
    Pro Git-- 跟踪分支
    Redis Tutorial
    linux 命令--文件操作
    分库分表的几种常见形式
    乐观锁与悲观锁
  • 原文地址:https://www.cnblogs.com/shenben/p/5558843.html
Copyright © 2011-2022 走看看