日志4高精度a+b
#include <bits/stdc++.h>
using namespace std;
int t, p, q, i;
string a, b;
int main() {
cin >> t;
while (t--) {
int A[5002] = {0}, B[5002] = {0};
cin >> a >> b;
p = a.length();
q = b.length();
//将字符串 a 和 b 转换为数组 A 和 B,并反转顺序以便从最低位开始相加。
for (i = 0; i < p; i++)
A[i] = a[p - i - 1] - '0';
for (i = 0; i < q; i++)
B[i] = b[q - i - 1] - '0';
//逐位相加 A 和 B,处理进位。
for (i = 0; i < max(p, q); i++) {
A[i] += B[i];
A[i + 1] += A[i] / 10;
A[i] %= 10;
}
//找到结果的最高位实现前导零
while (i > 0 && A[i] == 0) i--;
//然后从最高位开始输出
for (; i >= 0; i--) cout << A[i];
cout << endl;
}
return 0;
}
using namespace std;
int t, p, q, i;
string a, b;
int main() {
cin >> t;
while (t--) {
int A[5002] = {0}, B[5002] = {0};
cin >> a >> b;
p = a.length();
q = b.length();
//将字符串 a 和 b 转换为数组 A 和 B,并反转顺序以便从最低位开始相加。
for (i = 0; i < p; i++)
A[i] = a[p - i - 1] - '0';
for (i = 0; i < q; i++)
B[i] = b[q - i - 1] - '0';
//逐位相加 A 和 B,处理进位。
for (i = 0; i < max(p, q); i++) {
A[i] += B[i];
A[i + 1] += A[i] / 10;
A[i] %= 10;
}
//找到结果的最高位实现前导零
while (i > 0 && A[i] == 0) i--;
//然后从最高位开始输出
for (; i >= 0; i--) cout << A[i];
cout << endl;
}
return 0;
}
全部评论
相关推荐
07-22 15:24
广西师范大学 大数据开发工程师 上周偶然刷到了lls的26秋招提前批开了,主包前段时间从字节实习完,秉持着投着试试的心态,认真填写了秋招的网申,提交成功的下一秒再刷新应聘页面,已经变成流程结束好夸张!是不是被机筛了,终究是双非不配了

点赞 评论 收藏
分享