1086: 【C3】【高精度】大整数减法

题目描述

求两个大的正整数相减的差

输入

共两行,第1行是被减数a,第2行是减数b(a > b)。每个大整数不超过200位

输出

一行,即所求的差

样例输入

复制代码
9999999999999999999999999999999999999
9999999999999

样例输出

复制代码
9999999999999999999999990000000000000

Code:

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int a[100005],b[100005],c[100005];
void jianfa(string sa,string sb){
    int alen=sa.size(),blen=sb.size(),jw=0,len;
    for(int i=0;i<alen;i++){
        a[i]=sa[alen-1-i]-'0';
    }
    for(int i=0;i<blen;i++){
        b[i]=sb[blen-1-i]-'0';
    }
    len=max(alen,blen);
    for(int i=0;i<len;i++){
        c[i]=a[i]-b[i]+c[i];
        if(c[i]<0){
            c[i+1]--;
            c[i]=10+c[i];
        }
    }
    while(len>1&&c[len-1]==0)len--;
    for(int i=len-1;i>=0;i--){
        cout<<c[i];
    }
}
int main(){
    string sa,sb;
    cin>>sa>>sb;
    while(1){
        if(sa[0]=='0')
        sa.erase(0,1);
        else
        break;
    }
    while(1){
        if(sb[0]=='0')
        sb.erase(0,1);
        else
        break;
    }
    jianfa(sa,sb);
    return 0;
}
相关推荐
bubiyoushang8882 分钟前
二维地质模型的表面重力值和重力异常计算
算法
仙俊红29 分钟前
LeetCode322零钱兑换
算法
颖风船32 分钟前
锂电池SOC估计的一种算法(改进无迹卡尔曼滤波)
python·算法·信号处理
551只玄猫1 小时前
KNN算法基础 机器学习基础1 python人工智能
人工智能·python·算法·机器学习·机器学习算法·knn·knn算法
charliejohn1 小时前
计算机考研 408 数据结构 哈夫曼
数据结构·考研·算法
POLITE31 小时前
Leetcode 41.缺失的第一个正数 JavaScript (Day 7)
javascript·算法·leetcode
CodeAmaz1 小时前
一致性哈希与Redis哈希槽详解
redis·算法·哈希算法
POLITE32 小时前
Leetcode 42.接雨水 JavaScript (Day 3)
javascript·算法·leetcode
Tim_102 小时前
【算法专题训练】36、前缀树路径和
算法