华为练习题系列---超长整数相加
题目描述
请设计一个算法完成两个超长正整数的加法。
输入描述:
输入两个字符串数字
输出描述:
输出相加后的结果,string型
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int main()
{
string addend;
string augend;
string ret;
while (cin >> addend >> augend)
{
int sign = 0;//进位标志
while (1)
{
//将两个字符串补齐为等长字符串
if (addend.size() < augend.size())
{
addend = '0' + addend;
}
else if (addend.size() > augend.size())
{
augend = '0' + augend;
}
else
{
break;
}
}
int len = addend.size();
vector<char> ret(len + 1);//保存结果
int sum = 0;//每位求和结果
int result = 0;//
for (int i = len - 1; i > -1; i--)
{
int temp1 = addend[i] - '0';//字符转换位数字
int temp2 = augend[i] - '0';
sum = sign + temp1 + temp2;
result = sum % 10;
sign = sum / 10;
ret[i + 1] = result + '0';
if (i == 0)//考虑最高位有进位
{
if (sign == 1)
{
ret[i] = 1;
}
else
{
ret[i] = 0;
}
}
}
if (ret[0] == 1)
{
cout << '1';
}
for (int i = 1; i < len + 1; i++)
{
cout << ret[i];
}
cout << endl;
}
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了