/*实现最大为300位的大整数加法,
输入数3位一节,以‘,’隔开,以‘b’结尾。
如123,456b*/
#include<iostream>
#include<string>
using namespace std;
int main()
{
int a[101];
int b[101];
for(int l=0;l<=100;l++)
{a[l]=0;
b[l] = 0;
}
char Biaodian;
int j=0,k=0,temp=0;
//输入被加数
cout<<"请输入被加数:"<<endl;
for(int i=100;i>0;i--)
{
cin>>a[i];
j++;
cin>>Biaodian;
if(Biaodian == 'b')
break;
}
//输出被加数
cout<<"你输入的被加数是:";
for(int p=100;p>100-j;p--)
cout<<a[p];
cout<<endl;
cout<<"请输入加数:"<<endl;
//输入加数
for(int m=100;m>0;m--)
{
cin>>b[m];
k++;
cin>>Biaodian;
if(Biaodian == 'b')
break;
}
//输出加数
cout<<"你输入的加数是:";
for(int q=100;q>100-k;q--)
cout<<b[q];
cout<<endl;
//开始计算
if(j<=k)
{
for(int r=0;r<=k;r++)
{
a[100-r] = a[100-r] + b[100-r] +temp;
if(temp!=0)
temp--;
if(a[100-r]>1000)
{
a[100-r] = a[100-r] - 1000;
temp++;
}
}
cout<<"两数之和为:";
for(i=100-k;i<=100;i++)
cout<<a[i];
cout<<endl;
}
if(j>k)
{
for(int r=0;r<=j;r++)
{
a[100-r] = a[100-r] + b[100-r] +temp;
if(temp!=0)
temp--;
if(a[100-r]>1000)
{
a[100-r] = a[100-r] - 1000;
temp++;
}
}
cout<<"两数之和为:";
for(i=100-k;i<=100;i++)
cout<<a[i];
cout<<endl;
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律