Java 處理超大數類型之BigInteger案例詳解
一、BigInteger介紹
如果在操作的時候一個整型數據已經超過瞭整數的最大類型長度 long 的話,則此數據就無法裝入,所以,此時要使用 BigInteger 類進行操作。這些大數都會以字符串的形式傳入。
BigInteger 相比 Integer 的確可以用 big 來形容。它是用於科學計算,Integer 隻能容納一個 int,所以,最大值也就是 2 的 31 次訪減去 1,十進制為 2147483647。但是,如果需要計算更大的數,31 位顯然是不夠用的,那麼,此時 BigInteger 就能滿足我們的需求瞭。
BigInteger 能夠容納的位數那可就大瞭,我簡單試瞭一下,上千位沒有任何問題。除瞭容量大之外,BigInteger 還封裝瞭一些常見的操作,比如 ±*/ 的基本操作,還有絕對值,相反數,最大公約數,是否是質數等等的運算。
二、BigInteger常見函數
- BigInteger(String value):構造方法,
- BigInteger add(BigInteger value):加法,
- BigInteger subtract(BigInteger value):減法,
- BigInteger multiply(BigInteger value):乘法,
- BigInteger divide(BigInteger divisor):除法,
- BigInteger modInverse(BigInteger m):求模,
- BigInteger pow(int exponent):乘方,
- BigInteger max(BigInteger value):最大數,
- BigInteger min(BigInteger value):最小數,
- BigInteger abs():絕對值,
- BigInteger negate():相反數,
- int intValue():轉化int,將BigInteger類型數據轉為int。
- BigInteger valueOf(long val):轉為BigInteger,將long類型轉為BigIntege類型
示例代碼
【題目】
輸入一個整數 n 1<n<10^9
輸出一個整數
找出其所有非空子集中所有元素個數之和,然後對 10^9+7 取模,輸出結果
例如輸入 2,有 {1},{2},{1,2} 3 個非空子集,所有元素個數之和為 4
輸出結果為 4
思路
用 int 肯定會超,需要用到 BigInteger
對於輸入 n,求得所有元素之和為 n*2^(n-1)
然後再對 10^7+7 取模即可
import java.math.BigInteger; import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); String n = sc.next(); BigInteger res = count(new BigInteger(n)); BigInteger m = BigInteger.valueOf(10).pow(7).add(BigInteger.valueOf(7)); System.out.println(res.mod(m));; } // 計算公式 n*2^(n-1) static BigInteger count(BigInteger n) { return n.multiply(BigInteger.valueOf(2).pow(n.intValue()-1)); } }
到此這篇關於Java 處理超大數類型之BigInteger案例詳解的文章就介紹到這瞭,更多相關Java 處理超大數類型之BigInteger內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Java Big Number操作BigInteger及BigDecimal類詳解
- java中求高精度除法,要求保留N位小數
- 使用BigInteger實現除法取餘
- JAVA biginteger類bigdecimal類的使用示例學習
- Java 包裝類型及易錯陷阱詳解