你会用Java实现两个大数相加吗
生活随笔
收集整理的這篇文章主要介紹了
你会用Java实现两个大数相加吗
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
兩個大數相加(Java)* 1、是整數;* 2、兩個數無限大,long都裝不下;* 3、不能用BigInteger;* 4、不能用任何包裝類提供的運算方法;* 5、兩個數都是以字符串的方式提供。
?
* 思路:* 字符串逐位相加,需要進位則進位處理,考慮兩個問題:* 1、char怎么轉換為integer, 減去'0'即可* 2、怎么處理對應位相加?反轉字符串相加,正確處理進位即可,* 這樣個位對應個位,十位對應十位,剩余的直接追加 public class TwoBigIntegerSum {public String twoBigIntegerSum(String str1, String str2) {if (str1 == null || "".equals(str1)) {return str2;}if (str2 == null || "".equals(str2)) {return str1;}StringBuilder sb = new StringBuilder();char[] arr1 = str1.toCharArray();char[] arr2 = str2.toCharArray();int index1 = str1.length() - 1;int index2 = str2.length() - 1;//緩存是否需要進位boolean carry = false;while (index1 >= 0 && index2 >= 0) {char cur1 = arr1[index1];char cur2 = arr2[index2];int sum = cur1 - '0' + cur2 - '0';sum = carry ? sum + 1 : sum;carry = sum >= 10 ? true : false;sb.append((char) ((sum % 10) + '0'));index1--;index2--;}//處理剩余元素while (carry || index1 >= 0 || index2 >= 0) {if (index1 >= 0) {int sum = arr1[index1] - '0' + (carry ? 1 : 0);carry = sum >= 10 ? true : false;sb.append((char) ((sum % 10) + '0'));index1--;}else if (index2 >= 0) {int sum = arr2[index2] - '0' + (carry ? 1 : 0);carry = sum >= 10 ? true : false;sb.append((char) ((sum % 10) + '0'));index2--;}else {sb.append('1');carry = false;}}return sb.reverse().toString();}public static void main(String[] args) {String str1 = "11111112345678911111";String str2 = "2222";System.out.println(new TwoBigIntegerSum().twoBigIntegerSum(str1,str2));System.out.println(new BigInteger(str1).add(new BigInteger(str2)));String str3 = "999928";String str4 = "72";System.out.println(new TwoBigIntegerSum().twoBigIntegerSum(str3, str4));System.out.println(new BigInteger(str3).add(new BigInteger(str4)));} }?
總結
以上是生活随笔為你收集整理的你会用Java实现两个大数相加吗的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mysql模糊匹配查询_Mysql之模糊
- 下一篇: php 模糊匹配_PHP实现多字段模糊匹