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

    你可能感兴趣的文章
    OA项目之我的会议(会议排座&送审)
    查看>>
    OA项目之我的会议(查询)
    查看>>
    OA项目之我的审批(会议查询&会议签字)
    查看>>
    OA项目之项目简介&会议发布
    查看>>
    ObjC的复制操作
    查看>>
    Object c将一个double值转换为时间格式
    查看>>
    object detection之Win10配置
    查看>>
    object detection训练自己数据
    查看>>
    object detection错误Message type "object_detection.protos.SsdFeatureExtractor" has no field named "bat
    查看>>
    object detection错误之Could not create cudnn handle: CUDNN_STATUS_INTERNAL_ERROR
    查看>>
    object detection错误之no module named nets
    查看>>
    Object of type 'ndarray' is not JSON serializable
    查看>>
    Object Oriented Programming in JavaScript
    查看>>
    object references an unsaved transient instance - save the transient instance before flushing
    查看>>
    Object 类的常见方法有哪些?
    查看>>
    Object-c动态特性
    查看>>
    Object.assign用法
    查看>>
    Object.create
    查看>>
    Object.defineProperty详解
    查看>>
    Object.keys()的详解和用法
    查看>>