重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
怎么在java中实现两个大数相加?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。
站在用户的角度思考问题,与客户深入沟通,找到永州网站设计与永州网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:网站设计制作、做网站、企业官网、英文网站、手机端网站、网站推广、国际域名空间、网络空间、企业邮箱。业务覆盖永州地区。代码如下:
public class BigIntAdd { private int[] array; //声明一个数组 //计算大数相加的函数 public static String bigAdd(BigIntAdd fisrtNum, BigIntAdd secondNum) { String result = ""; Boolean falg = false; //判断数组是否越界的标志 int[] arrayOne; int[] arrayTwo; int[] arrayThree = null; //把较长的字符串放到arrayOne数组中,因为要把计算结果放到arrayOne数组中 if (fisrtNum.instance().length >= secondNum.instance().length) { arrayOne = fisrtNum.instance(); arrayTwo = secondNum.instance(); } else { arrayOne = secondNum.instance(); arrayTwo = fisrtNum.instance(); } for (int i = 0; i < arrayTwo.length; i++) { if (arrayOne[i] + arrayTwo[i] < 10) { //不需要进位时 arrayOne[i] = arrayOne[i] + arrayTwo[i]; } else if (arrayOne[i] + arrayTwo[i] >= 10) { //需要进位时 arrayOne[i] = arrayOne[i] + arrayTwo[i] - 10; if ((i + 1) < arrayOne.length) { arrayOne[i + 1] = arrayOne[i + 1] + 1; //下一位的值加1 } else { //当arrayOne的长度不够时要把其复制到arrayThree中 falg = true; arrayThree = new int[arrayOne.length + 1]; System.arraycopy(arrayOne, 0, arrayThree, 0,arrayOne.length); arrayThree[arrayOne.length] = 1; //把arrayThree最高位赋值1,等价于进位的1 } } } //把数组arrayThree中的元素全部的拼接为字符串 if (falg) { for (int i : arrayThree) { result += i; } } else { for (int i : arrayOne) { result += i; } } //把结果反转返回 return new StringBuffer(result).reverse().toString(); } //初始化数组方法 private int[] instance() { return array; } //初始化构造方法 public BigIntAdd(String num) { StringBuffer sb = new StringBuffer(num); String string = sb.reverse().toString(); //实现字符串反转,便于计算 array = new int[string.length()]; //把字符串转化为数组 for (int i = 0; i < string.length(); i++) { array[i] = Integer.valueOf(string.substring(i, i + 1)); } } public static void main(String [] args){ String result=BigIntAdd.bigAdd(new BigIntAdd("5211111111"), new BigIntAdd("4099999999")); System.out.println(result); } }
结果:
看完上述内容,你们掌握怎么在java中实现两个大数相加的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注创新互联行业资讯频道,感谢各位的阅读!