博客
关于我
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/

    你可能感兴趣的文章
    php PSR规范
    查看>>
    php rand() 重复,array_rand()函数从另外一个数组中随机取得的一定数量的数组的元素是否会重复?...
    查看>>
    php redis pub/sub(Publish/Subscribe,发布/订阅的信息系统)之基本使用
    查看>>
    php redis 集群扩展类文件
    查看>>
    php redis(2)
    查看>>
    PHP Redis分布式锁
    查看>>
    php redis的应用
    查看>>
    php rss,如何用PHP编写RSS
    查看>>
    php session超时时间_php怎么设置session超时时间
    查看>>
    PHP SOAP模块的使用方法:NON-WSDL模式
    查看>>
    PHP Socket实现websocket(三)Stream函数
    查看>>
    php Socket通信
    查看>>
    PHP SPL标准库-迭代器
    查看>>
    php static 变量
    查看>>
    PHP Static延迟静态绑定
    查看>>
    php str_pad();
    查看>>
    PHP study 环境变量composer
    查看>>
    PHP trim() 函数
    查看>>
    php unicode编码转成unioce字符(中文)
    查看>>
    php url路径问题和php文件以绝对路径引入
    查看>>