java編程實(shí)現(xiàn)兩個(gè)大數(shù)相加代碼示例
通常情況,實(shí)現(xiàn)大數(shù)運(yùn)算是通過(guò)BigInteger和BigDecimal兩種方法。這兩種方法分別表示不可變的任意精度的整數(shù)和不可變的有符號(hào)的任意精度的十進(jìn)制數(shù)(浮點(diǎn)數(shù))。主要用于高精度計(jì)算中。這兩個(gè)類使得java中的大數(shù),高精度運(yùn)算變得很簡(jiǎn)單。但本文介紹的并不是通過(guò)上述兩種方法實(shí)現(xiàn)Java中的大數(shù)運(yùn)算。
主要的思想是:把兩個(gè)數(shù)存在String中了,然后將每個(gè)數(shù)字取出,放到數(shù)組,由最末位開(kāi)始計(jì)算,算加法,判斷是否進(jìn)位,進(jìn)位則前位+1,若超過(guò)長(zhǎng)度,則copy到新的數(shù)組。
代碼如下:
public class BigIntAdd { private int[] array; //聲明一個(gè)數(shù)組 //計(jì)算大數(shù)相加的函數(shù) public static String bigAdd(BigIntAdd fisrtNum, BigIntAdd secondNum) { String result = ""; Boolean falg = false; //判斷數(shù)組是否越界的標(biāo)志 int[] arrayOne; int[] arrayTwo; int[] arrayThree = null; //把較長(zhǎng)的字符串放到arrayOne數(shù)組中,因?yàn)橐延?jì)算結(jié)果放到arrayOne數(shù)組中 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) { //不需要進(jìn)位時(shí) arrayOne[i] = arrayOne[i] + arrayTwo[i]; } else if (arrayOne[i] + arrayTwo[i] >= 10) { //需要進(jìn)位時(shí) arrayOne[i] = arrayOne[i] + arrayTwo[i] - 10; if ((i + 1) < arrayOne.length) { arrayOne[i + 1] = arrayOne[i + 1] + 1; //下一位的值加1 } else { //當(dāng)arrayOne的長(zhǎng)度不夠時(shí)要把其復(fù)制到arrayThree中 falg = true; arrayThree = new int[arrayOne.length + 1]; System.arraycopy(arrayOne, 0, arrayThree, 0,arrayOne.length); arrayThree[arrayOne.length] = 1; //把a(bǔ)rrayThree最高位賦值1,等價(jià)于進(jìn)位的1 } } } //把數(shù)組arrayThree中的元素全部的拼接為字符串 if (falg) { for (int i : arrayThree) { result += i; } } else { for (int i : arrayOne) { result += i; } } //把結(jié)果反轉(zhuǎn)返回 return new StringBuffer(result).reverse().toString(); } //初始化數(shù)組方法 private int[] instance() { return array; } //初始化構(gòu)造方法 public BigIntAdd(String num) { StringBuffer sb = new StringBuffer(num); String string = sb.reverse().toString(); //實(shí)現(xiàn)字符串反轉(zhuǎn),便于計(jì)算 array = new int[string.length()]; //把字符串轉(zhuǎn)化為數(shù)組 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); } }
結(jié)果:
總結(jié)
以上就是本文關(guān)于java編程實(shí)現(xiàn)兩個(gè)大數(shù)相加代碼示例的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題,如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
相關(guān)文章
springboot 按月分表的實(shí)現(xiàn)方式
本文主要介紹了springboot 按月分表的實(shí)現(xiàn)方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04Java?Stream.reduce()用法詳細(xì)解析
Stream API提供了豐富的中間函數(shù),歸并函數(shù)和終端函數(shù),這些函數(shù)還支持并行化執(zhí)行,下面這篇文章主要給大家介紹了關(guān)于Java?Stream.reduce()用法的相關(guān)資料,需要的朋友可以參考下2022-12-12java實(shí)戰(zhàn)CPU占用過(guò)高問(wèn)題的排查及解決
這篇文章給大家分享了java實(shí)戰(zhàn)CPU占用過(guò)高問(wèn)題的排查及解決方法,有需要的朋友們可以學(xué)習(xí)下。2018-08-08淺談java多線程 join方法以及優(yōu)先級(jí)方法
下面小編就為大家?guī)?lái)一篇淺談java多線程 join方法以及優(yōu)先級(jí)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-01-01關(guān)于Java繼承中父類和子類構(gòu)造函數(shù)的問(wèn)題
這篇文章主要介紹了關(guān)于Java繼承中父類和子類構(gòu)造函數(shù)的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-10-10java自定義任務(wù)類定時(shí)執(zhí)行任務(wù)示例 callable和future接口使用方法
Callable是類似于Runnable的接口,實(shí)現(xiàn)Callable接口的類和實(shí)現(xiàn)Runnable的類都是可被其它線程執(zhí)行的任務(wù)2014-01-01SpringBoot使用CXF集成WebService的方法
這篇文章主要介紹了SpringBoot使用CXF集成WebService的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-08-08Java開(kāi)發(fā)之普通web項(xiàng)目轉(zhuǎn)為Maven項(xiàng)目的方法
這篇文章主要給大家介紹了關(guān)于Java開(kāi)發(fā)之普通web項(xiàng)目轉(zhuǎn)為Maven項(xiàng)目的相關(guān)資料,文中通過(guò)圖文將轉(zhuǎn)換的方法步驟介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12