高精度A+B、A-B、A*B、A/B


前言

提示:以下是本篇文章正文内容,下面案例可供参考

一、高精加

#include <iostream>
using namespace std;
int ab[5005];//存储这个大数的每一位,0-len 从个位到高位
string a,b;//定义两个字符串来存储一个大数
int main()
{
   
    cin>>a>>b;//输入这两个大数
    int lena=a.size();//算出大数a的位数
    int lenb=b.size();//算出大数b的位数
    int len= max(lena,lenb);//两个数的最大数
    if(lena>=lenb) {
   //用较大的大数加较小的大数
        for (int i = 0; i < lena; ++i) {
   //将第一个数的每一位转换为int型数字,再存入数组
            ab[i] = a[lena - 1 - i] - 48;
        }
        for (int i = 0; i < lenb; ++i) {
   //将第二个数的每一位转换为int型数字,与第一位的数字相加,再存入数组
            ab[i]+= b[lenb - 1 - i] - 48;
        }
    }
    else{
   
        for (int i = 0; i < lenb; ++i) {
   //将第一个数的每一位转换为int型数字,再存入数组
            ab[i] = b[lenb - 1 - i] - 48;
        }
        for (int i = 0; i < lena; ++i) {
   //将第二个数的每一位转换为int型数字,与第一位的数字相加,再存入数组
            ab[i]+= a[lena - 1 - i] - 48;
        }
    }
    for (int i = 0; i <len ; ++i) {
   //遍历数组,如果数大于9,位数就要进一位
        if(ab[i]>=10){
   
            ab[i]-=10;
            ab[i+1]++;
        }
    }
    while(a[len]>0){
   //判断最大位的上一位是否大于0,如果大于,位数就加
        len++;
    }
    for(int i=len-1;i>=0;i--){
   //最后从最高位开始输出
        cout<<ab[i];
    }
    return 0;
}

二、高精减

代码如下(示例):

#include <iostream>
using name
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值