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
    版权声明:本文为博主原创文章,转载请附上博文链接!

  • 相关阅读:
    centos7源以及相关的一些命令
    创建Vue实例的三种方法
    github 钩子管理工具 overcommit
    npm管理registry 【转】
    两个字典增量部分
    celery (二) task调用
    shell编程
    linux 环境变量 转
    celery (二) task
    celery(一) application
  • 原文地址:https://www.cnblogs.com/ning123/p/10919605.html
Copyright © 2011-2022 走看看