日志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;
}
全部评论
相关推荐
专业嗎喽:硕佬,把学校背景放后面几段,学校背景双非还学院,让人看了就不想往下看。
把实习经历和个人奖项放前面,用数字化简述自己实习的成果和掌握的技能,比如负责项目一次通过率90%,曾4次发现项目潜在问题风险为公司减少损失等等 点赞 评论 收藏
分享