您好,登錄后才能下訂單哦!
怎么在java中實現(xiàn)兩個大數(shù)相加?相信很多沒有經(jīng)驗的人對此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。
代碼如下:
public class BigIntAdd { private int[] array; //聲明一個數(shù)組 //計算大數(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; //把較長的字符串放到arrayOne數(shù)組中,因為要把計算結(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)位時 arrayOne[i] = arrayOne[i] + arrayTwo[i]; } else if (arrayOne[i] + arrayTwo[i] >= 10) { //需要進(jìn)位時 arrayOne[i] = arrayOne[i] + arrayTwo[i] - 10; if ((i + 1) < arrayOne.length) { arrayOne[i + 1] = arrayOne[i + 1] + 1; //下一位的值加1 } else { //當(dāng)arrayOne的長度不夠時要把其復(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,等價于進(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(); //實現(xiàn)字符串反轉(zhuǎn),便于計算 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é)果:
看完上述內(nèi)容,你們掌握怎么在java中實現(xiàn)兩個大數(shù)相加的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。