博客
关于我
A + B Problem II HDU - 1002(简单string)
阅读量:173 次
发布时间:2019-02-28

本文共 1060 字,大约阅读时间需要 3 分钟。

#include 
#include
#include
using namespace std;string sum(string a, string b) { if (a.length() < b.length()) { string tmp = a; a = b; b = tmp; } string ans = ""; int carry = 0; for (int i = a.length() - b.length() - 1; i >= 0; i--) { int digitSum = a[i] - '0' + b[i] - '0' + carry; carry = digitSum / 10; ans = "0" + ans + (char)(digitSum % 10 + '0'); } if (carry) { ans = "1" + ans; } reverse(ans.begin(), ans.end()); return ans;}int main() { string str1, str2, ans; int n; cin >> n; for (int i = 1; i <= n; i++) { cin >> str1 >> str2; cout << "Case " << i << ":" << endl; cout << str1 << " + " << str2 << " = " << sum(str1, str2) << endl; if (i != n) { cout << endl; } } return 0;}

以上代码实现了两个字符串的加法,主要采用了仿射转换和进位处理的算法。代码中首先比较两个字符串的长度,确保a是较长的字符串,然后通过反向遍历逐位相加并处理进位。最后将结果反转得到最终的和。

这个实现的关键点在于:

  • 逐位相加并处理进位
  • 仿射转换确保两个字符串对齐
  • 最后反转结果以得到正确的顺序
  • 整体思路清晰,代码结构简洁易懂,适合学习字符串处理算法的入门级练习。

    转载地址:http://cdrn.baihongyu.com/

    你可能感兴趣的文章
    PANDAS.READ_EXCEL()输出‘;溢出错误:日期值超出范围‘;而不存在日期列
    查看>>
    pandas100个骚操作:再见 for 循环!速度提升315倍!
    查看>>
    Pandas:如何根据其他列值的条件对列进行求和?
    查看>>
    Pandas:对给定列求和 DataFrame 行
    查看>>
    Pandas、groupby 和特定月份的求和
    查看>>
    Pandas、Matplotlib、Pyecharts数据分析实践
    查看>>
    Pandas中文官档 ~ 基础用法1
    查看>>
    Pandas中文官档~基础用法2
    查看>>
    SpringBoot+Vue+OpenOffice实现文档管理(文档上传、下载、在线预览)
    查看>>
    Pandas中文官档~基础用法5
    查看>>
    Pandas中文官档~基础用法6
    查看>>
    Pandas中的GROUP BY AND SUM不丢失列
    查看>>
    Pandas中的GROUP BY AND SUM不丢失列
    查看>>
    Pandas之iloc、loc
    查看>>
    pandas交换两列
    查看>>
    pandas介绍-ChatGPT4o作答
    查看>>
    pandas删除指定列里面内容的行
    查看>>
    pandas去除Nan值
    查看>>
    vc++多线程编程
    查看>>
    pandas实战:电商平台用户分析
    查看>>