首页 > 其他 > 详细

大数相加

时间:2015-10-11 20:02:16      阅读:366      评论:0      收藏:0      [点我收藏+]
public class BigNumAdd {
 public static void main(String[] args) {
  String num1 = "1234";
  String num2 = "1234";
  String sum = bigNumberAdd(num1, num2);
  System.out.print(sum);
 }
 
 public static String bigNumberAdd(String f, String s) {
        //翻转两个字符串,并转换成数组
        char[] a = new StringBuffer(f).reverse().toString().toCharArray();
        char[] b = new StringBuffer(s).reverse().toString().toCharArray();
        int lenA = a.length;
        int lenB = b.length;
        //计算两个长字符串中的较长字符串的长度
        int len = lenA > lenB ? lenA : lenB;
        int[] result = new int[len + 1];
        for (int i = 0; i < len + 1; i++) {
            //如果当前的i超过了其中的一个,就用0代替,和另一个字符数组中的数字相加
            int aint = i < lenA ? (a[i] - ‘0‘) : 0;
            int bint = i < lenB ? (b[i] - ‘0‘) : 0;
            result[i] = aint + bint;
        }
        //处理结果集合,如果大于10的就向前一位进位,本身进行除10取余
        for (int i = 0; i < result.length; i++) {
            if (result[i] > 10) {
                result[i + 1] += result[i] / 10;
                result[i] %= 10;
            }
        }
        StringBuffer sb = new StringBuffer();
        //该字段用于标识是否有前置0,如果有就不要存储
        boolean flag = true;
        for (int i = len; i >= 0; i--) {
            if (result[i] == 0 && flag) {
                continue;
            } else {
                flag = false;
            }
            sb.append(result[i]);
        }
        return sb.toString();
    }
}

大数相加

原文:http://my.oschina.net/u/2350638/blog/515579

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!