前言
提示:以下是本篇文章正文内容,下面案例可供参考
一、高精加
#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