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

  • 相关阅读:
    开发趋势
    常用的meta
    meta基础
    HTTP请求方法GET和POST
    same-origin policy----wikipedia
    跨域——同源策略(译)
    DNS问答
    TCP/IP的整理
    鉴权方法
    Web攻击技术---OWASP top
  • 原文地址:https://www.cnblogs.com/ning123/p/10919605.html
Copyright © 2011-2022 走看看