P1601 A+B Problem(高精)

题目传送门
//P1601.cpp

#include <bits/stdc++.h>

using namespace std;

/**
 * 功能:高精度加法模板
 * @param A
 * @param B
 * @return
 */
vector<int> add(vector<int> &A, vector<int> &B) {
    //声明结果数组C
    vector<int> C;

    //以长的为根基,进行计算
    if (A.size() < B.size()) return add(B, A);
    //进位
    int t = 0;
    //列竖式进行计算
    for (int i = 0; i < A.size(); i++) {
        t += A[i];//进位加法
        if (i < B.size()) t += B[i]; //存在这一位,就加
        C.push_back(t % 10);//保留余数
        t /= 10;//进位
    }
    //最后可能还有进位
    if (t) C.push_back(t);
    //返回
    return C;
}

int main() {
    //以字符串形式读入
    string a, b;
    cin >> a >> b;
    //1、准备动作,将字符串的每一位,反序放入到整数运算数组中
    vector<int> A, B, C;
    for (int i = a.size() - 1; i >= 0; i--) A.push_back(a[i] - '0');
    for (int i = b.size() - 1; i >= 0; i--) B.push_back(b[i] - '0');

    //2、调用模板进行计算
    C = add(A, B);

    //3、输出结果,需要倒序噢
    for (int i = C.size() - 1; i >= 0; i--)printf("%d", C[i]);
    return 0;
}
posted @   糖豆爸爸  阅读(88)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
历史上的今天:
2014-11-21 mysql查看每张表的空间使用情况
Live2D
点击右上角即可分享
微信分享提示