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

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

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

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

简单思路就是  多个字符串的每一位进行相加,如果有进位 ,则让进位也一起相加; String a = "123456789" String b = "123" 这种情况就要让b变成 String b = "000000123" 与a的每一位进行相加


show the code

/**
* Created by shirenchuang on 2018/6/28.
*/

publicclassBigDataAddUtils {
   publicstatic 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();
   }

   publicstaticvoidmain(String[] args) {
       System.out.print(add("10023888888888842340","9133333333319","1912"));
   }
}

写完之后,面试官问我还有没有更好的解法; emmmmm....暂时还没有想到更好的解法,求告知!

相关文章
|
2月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
2月前
|
Java 编译器 C++
【Java基础面试一】、为什么Java代码可以实现一次编写、到处运行?
这篇文章解释了Java能够实现“一次编写,到处运行”的原因,主要归功于Java虚拟机(JVM),它能够在不同平台上将Java源代码编译成的字节码转换成对应平台的机器码,实现跨平台运行。
【Java基础面试一】、为什么Java代码可以实现一次编写、到处运行?
|
2月前
|
Java
【Java基础面试四】、介绍一下Java的数据类型
这篇文章介绍了Java的数据类型,包括8种基本数据类型(整数、浮点、字符、布尔)和3类引用数据类型(数组、类、接口),并提供了基本数据类型所占内存空间和数据范围的详细信息。
|
2月前
|
Java C++
【Java基础面试十七】、Java为什么是单继承,为什么不能多继承?
这篇文章讨论了Java单继承的设计原因,指出Java不支持多继承主要是为了避免方法名冲突等混淆问题,尽管Java类不能直接继承多个父类,但可以通过接口和继承链实现类似多继承的效果。
【Java基础面试十七】、Java为什么是单继承,为什么不能多继承?
|
2月前
|
Java
【Java基础面试三】、说一说你对Java访问权限的了解
这篇文章介绍了Java中的四种访问权限:private、default(无修饰符时的访问权限)、protected和public,以及它们分别在修饰成员变量/方法和类时的不同访问级别和规则。
【Java基础面试三】、说一说你对Java访问权限的了解
|
2月前
|
存储 缓存 网络协议
复盘女朋友面试4个月的Java基础题
这篇文章是关于Java基础面试题的复盘,涵盖了HashMap原理、对象序列化作用等高频面试问题,并强调了Java基础知识的重要性。
复盘女朋友面试4个月的Java基础题
|
2月前
|
Java
【Java基础面试二】、个Java文件里可以有多个类吗(不含内部类)?
这篇文章讨论了Java文件中类的定义规则,指出一个Java文件可以包含多个类(不包含内部类),但其中最多只能有一个public类,且如果有public类,它的名称必须与文件名一致。
|
2月前
|
XML 存储 JSON
【IO面试题 六】、 除了Java自带的序列化之外,你还了解哪些序列化工具?
除了Java自带的序列化,常见的序列化工具还包括JSON(如jackson、gson、fastjson)、Protobuf、Thrift和Avro,各具特点,适用于不同的应用场景和性能需求。
|
2月前
|
Java
【Java基础面试三十七】、说一说Java的异常机制
这篇文章介绍了Java异常机制的三个主要方面:异常处理(使用try、catch、finally语句)、抛出异常(使用throw和throws关键字)、以及异常跟踪栈(异常传播和程序终止时的栈信息输出)。
|
2月前
|
Java
【Java基础面试三十八】、请介绍Java的异常接口
这篇文章介绍了Java的异常体系结构,主要讲述了Throwable作为异常的顶层父类,以及其子类Error和Exception的区别和处理方式。
下一篇
无影云桌面