【面试题】Java 2个(多个)大整数相加如何实现

简介: 【面试题】Java 2个(多个)大整数相加如何实现

之前面试阿里的时候,第四面的时候面试官让我当他面实现这个题目,

一开始的时候问的时候 2个相加如何实现,然后我写完了之后又问我如果是多个相加呢?面试官希望我能在实现的时候能够考虑到各种可能性,比如多个数相加,然后等我写完了之后,又问我有没有更好的实现方法;以下是我的实现方法;


将待相加的数以字符串的形式进行相加

简单思路就是 多个字符串的每一位进行相加,如果有进位 ,则让进位也一起相加;

String a = “123456789”

String b = “123”

这种情况就要让b变成

String b = “000000123” 与a的每一位进行相加


show the code

/**
 * Created by shirenchuang on 2018/6/28.
 */
public class BigDataAddUtils {
    public static String add(String... params){
        int maxLeng = 0;
        //获取最大长度
        for(String s :params){
            if(s.length()>maxLeng)maxLeng=s.length();
        }
        StringBuffer result = new StringBuffer();
        //进位 数
        int high= 0;
        //将每个待加参数每一位相加 进位
        for (int i = 0 ;i<maxLeng;i++){
            int charInt = 0;
            for(String s :params){
                //高位不够用0代替
                charInt += s.length()-1<i?0: Integer.parseInt(s.charAt(s.length()-1-i)+"");
            }
            charInt+=high;
            //进位
            high = charInt/10;
            //当前位的值 为charInt 余数
            int remainder = charInt%10;
            result.append(remainder);
        }
        //最后一次进位
        if(high>0){
            result.append(high);
        }
        //反转 输出结果
        return result.reverse().toString();
    }
    public static void main(String[] args) {
        System.out.print(add("10023888888888842340","9133333333319","1912"));
    }
}


相关文章
|
8月前
|
Java
Java中整数(负数)的二进制表示
Java中整数(负数)的二进制表示
|
8月前
|
算法 Java
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
[Java·算法·简单] LeetCode 13. 罗马数字转整数 详细解读
73 0
|
4月前
|
Java
java基础(10)数据类型中的整数类型
Java中的整数类型包括byte、short、int和long。整数字面值默认为int类型,加L表示long类型。整数字面值可以是十进制、八进制(0开头)或十六进制(0x开头)。小容量类型(如int)可自动转换为大容量类型(如long),但大容量转小容量需强制转换,可能导致精度损失。
61 2
|
7月前
|
Java 程序员
程序员必知:【java】判断字符串是否整数的三种方式,孰优孰劣请自行判断
程序员必知:【java】判断字符串是否整数的三种方式,孰优孰劣请自行判断
204 3
|
7月前
|
Java
剑指offer_1_整数除法(java)
剑指offer_1_整数除法(java)
|
8月前
|
Java
Java 中表示整数的包装类Integer(详解)
Java 中表示整数的包装类Integer(详解)
|
8月前
|
Java
JAVA输入任意一个数字,实现递减求和(计算任意整数n的和)
JAVA输入任意一个数字,实现递减求和(计算任意整数n的和)
63 0
|
8月前
|
算法 Java 开发者
Java:求正整数分解为质因数Java
Java:求正整数分解为质因数Java
|
8月前
|
Java Go C++
Golang每日一练(leetDay0085) 2的幂、数字 1 的个数
Golang每日一练(leetDay0085) 2的幂、数字 1 的个数
54 0
Golang每日一练(leetDay0085) 2的幂、数字 1 的个数
|
8月前
|
算法 C++ Python
Java每日一练(20230430) 文本左右对齐、素数和、整数转英文表示
Java每日一练(20230430) 文本左右对齐、素数和、整数转英文表示
59 0
Java每日一练(20230430) 文本左右对齐、素数和、整数转英文表示