zoukankan      html  css  js  c++  java
  • 大数相加算法

    @Test
    public void testBig() {
    System.out.println(bigAdd("123456789", "9999999999999999999999999"));
    }

    public static String bigAdd(String a, String b) {
    char[] charsA = new StringBuilder(a).reverse().toString().toCharArray();
    char[] charsB = new StringBuilder(b).reverse().toString().toCharArray();

    int maxLength = Math.max(charsA.length, charsB.length);

    int[] result = new int[maxLength + 1];

    int temp = 0;
    for (int i = 0; i <= maxLength; i++) {
    temp = result[i];

    if (i < charsA.length) {
    temp += charsA[i] - '0';
    }

    if (i < charsB.length) {
    temp += charsB[i] - '0';
    }

    if (temp >= 10) {
    temp -= 10;
    result[i + 1] = 1;
    }

    result[i] = temp;

    }

    StringBuilder sb = new StringBuilder();
    boolean flag = true;

    for (int i = maxLength; i >= 0; i--) {
    if (result[i] == 0 && flag) {
    continue;
    }

    flag = false;
    sb.append(result[i]);
    }

    return sb.toString();

    }
    ---------------------
    作者:懒惰的毛毛虫
    来源:CSDN
    原文:https://blog.csdn.net/u013278314/article/details/85171400
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    单例和静态类
    Aggregate
    lc.exe已退出代码为1
    MVC 使用entity framework 访问数据库 发布IIS
    MVC 发布
    Nhiberate (三)测试
    Nhiberate (二) 搭项目
    初次安装git配置
    十大Intellij IDEA快捷键(转)
    Git强制覆盖master分支
  • 原文地址:https://www.cnblogs.com/ning123/p/10919605.html
Copyright © 2011-2022 走看看