java編程實現(xiàn)兩個大數(shù)相加代碼示例
通常情況,實現(xiàn)大數(shù)運算是通過BigInteger和BigDecimal兩種方法。這兩種方法分別表示不可變的任意精度的整數(shù)和不可變的有符號的任意精度的十進制數(shù)(浮點數(shù))。主要用于高精度計算中。這兩個類使得java中的大數(shù),高精度運算變得很簡單。但本文介紹的并不是通過上述兩種方法實現(xiàn)Java中的大數(shù)運算。
主要的思想是:把兩個數(shù)存在String中了,然后將每個數(shù)字取出,放到數(shù)組,由最末位開始計算,算加法,判斷是否進位,進位則前位+1,若超過長度,則copy到新的數(shù)組。
代碼如下:
public class BigIntAdd {
private int[] array;
//聲明一個數(shù)組
//計算大數(shù)相加的函數(shù)
public static String bigAdd(BigIntAdd fisrtNum, BigIntAdd secondNum) {
String result = "";
Boolean falg = false;
//判斷數(shù)組是否越界的標志
int[] arrayOne;
int[] arrayTwo;
int[] arrayThree = null;
//把較長的字符串放到arrayOne數(shù)組中,因為要把計算結果放到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) {
//不需要進位時
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
}
}
}
//把數(shù)組arrayThree中的元素全部的拼接為字符串
if (falg) {
for (int i : arrayThree) {
result += i;
}
} else {
for (int i : arrayOne) {
result += i;
}
}
//把結果反轉返回
return new StringBuffer(result).reverse().toString();
}
//初始化數(shù)組方法
private int[] instance() {
return array;
}
//初始化構造方法
public BigIntAdd(String num) {
StringBuffer sb = new StringBuffer(num);
String string = sb.reverse().toString();
//實現(xiàn)字符串反轉,便于計算
array = new int[string.length()];
//把字符串轉化為數(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);
}
}
結果:

總結
以上就是本文關于java編程實現(xiàn)兩個大數(shù)相加代碼示例的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關專題,如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!
相關文章
java自定義任務類定時執(zhí)行任務示例 callable和future接口使用方法
Callable是類似于Runnable的接口,實現(xiàn)Callable接口的類和實現(xiàn)Runnable的類都是可被其它線程執(zhí)行的任務2014-01-01
SpringBoot使用CXF集成WebService的方法
這篇文章主要介紹了SpringBoot使用CXF集成WebService的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-08-08
Java開發(fā)之普通web項目轉為Maven項目的方法
這篇文章主要給大家介紹了關于Java開發(fā)之普通web項目轉為Maven項目的相關資料,文中通過圖文將轉換的方法步驟介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-12-12

