zoukankan      html  css  js  c++  java
  • 【洛谷】P1601 A+B Problem 高精(高精度加法模板)

    加法高精度模板

    【洛谷】P1601 A+B Problem 高精

    原理

    高精度计算一般用到数组。
    把输入的数字倒着存就可以实现竖式计算里面向右对齐。
    最后再判断进位,输出时最高位特判即可。

    代码

    /* P1601 A+B Problem 高精
     * 来源:洛谷
     * 作者:RainbowBird
     * 日期:2020年6月6日
     * 算法:高精度加法
     */
    
    #include <algorithm>
    #include <cstdio>
    #include <cstring>
    #include <iostream>
    using namespace std;
    
    int a[505], b[505], c[505];
    char stra[505], strb[505];
    
    int main() {
        scanf("%s %s", &stra, &strb);
        int lena = strlen(stra);
        int lenb = strlen(strb);
        int len = max(lena, lenb);
    
        // 靠右对齐
        for (int i = strlen(stra); i > 0; i--)
            a[lena - i + 1] = stra[i - 1] - '0';
        for (int j = strlen(strb); j > 0; j--)
            b[lenb - j + 1] = strb[j - 1] - '0';
    
        // 核心部分
        for (int i = 1; i <= len; i++) {
            c[i] += a[i] + b[i];
            // 判断进位
            if (c[i] >= 10) {
                c[i] -= 10;
                c[i + 1]++;
            }
        }
    
        if (c[len + 1] != 0) // 最高位特判
            printf("%d", c[len + 1]); // 输出最高位
        
        for (int i = len; i > 0; i--) {
            printf("%d", c[i]); // 倒着输出
        }
    
        return 0;
    }
    
  • 相关阅读:
    类与继承
    闭包、原型链和继承
    ajax(下)和“承诺”
    ajax(上)
    Ubuntu电源键软关机设置
    金老师语录摘要(七)
    金老师语录摘要(六)
    金老师语录摘要(四)
    金老师语录摘要(三)
    金老师语录摘要(二)
  • 原文地址:https://www.cnblogs.com/luoling8192/p/13054037.html
Copyright © 2011-2022 走看看