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!

推薦閱讀: