java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Java BigInteger类常用操作

一文让你彻底学会Java之BigInteger类常用操作

作者:凭君语未可

这篇文章主要介绍了Java之BigInteger类常用操作的相关资料,BigInteger是Java中用于表示任意精度整数的类,解决了基本数据类型精度限制问题,文中通过代码介绍的非常详细,需要的朋友可以参考下

BigInteger 的基本概念

1. 什么是 BigInteger

2. 特点

BigInteger 的构造方式

构造函数

BigInteger 提供了多个构造器用于创建实例。

1. 使用字符串构造

这是最常用的构造方法,支持任意大小的数字:

BigInteger bigInt = new BigInteger("123456789012345678901234567890");

2. 使用基本数据类型的转换

通过静态方法 BigInteger.valueOf 将 int 或 long 转换为 BigInteger

BigInteger bigInt = BigInteger.valueOf(123456789L);

3. 从二进制、八进制、十六进制等进制构造

支持指定进制的字符串构造:

BigInteger bigInt = new BigInteger("1010", 2); // 二进制 -> 十进制:10
BigInteger hexInt = new BigInteger("1A", 16); // 十六进制 -> 十进制:26

4. 生成随机数

通过构造一个随机数:

BigInteger randomBigInt = new BigInteger(50, new Random()); // 生成 50 位随机数

5. 常用常量

BigInteger.ZERO   // 表示 0
BigInteger.ONE    // 表示 1
BigInteger.TEN    // 表示 10

BigInteger 的常用操作

1. 算术运算

BigInteger a = new BigInteger("12345");
BigInteger b = new BigInteger("67890");

加法

BigInteger sum = a.add(b); // 结果:80235

减法

BigInteger diff = a.subtract(b); // 结果:-55545

乘法

BigInteger product = a.multiply(b); // 结果:838102050

除法

BigInteger quotient = b.divide(a); // 结果:5

取模

BigInteger mod = b.remainder(a); // 结果:12345

混合运算:加法、乘法

所有的运算都是链式的。例如:

BigInteger result = a.add(b).multiply(a).divide(b);

2. 幂运算

BigInteger base = new BigInteger("2");
BigInteger result = base.pow(10); // 2^10 = 1024
BigInteger base = new BigInteger("2");
BigInteger exp = new BigInteger("10");
BigInteger mod = new BigInteger("7");
BigInteger modPowResult = base.modPow(exp, mod); // (2^10) % 7 = 2

底层优化:

3. 比较和最大最小值

比较大小

compareTo 方法返回以下结果:

int compare = a.compareTo(b);

最大值和最小值

BigInteger max = a.max(b);
BigInteger min = a.min(b);

4. 位运算

按位操作

BigInteger result = a.and(b);
BigInteger result = a.or(b);
BigInteger result = a.xor(b);

位移操作

BigInteger result = a.shiftLeft(2); // 左移 2 位
BigInteger result = a.shiftRight(2); // 右移 2 位

5. 数学相关

求绝对值

BigInteger abs = a.abs();

求最大公约数

BigInteger gcd = a.gcd(b); // 返回 a 和 b 的最大公约数

模反元素

模反元素是满足以下公式的整数:

( a × x ) % m = 1 (a \times x) \% m = 1(a×x)%m=1

代码示例:

BigInteger modInverse = a.modInverse(mod); // 计算 a 的模反元素

检查是否是质数

boolean isPrime = a.isProbablePrime(10); // 参数为测试的可信度

6. 进制转换

String decimalStr = a.toString();
String binaryStr = a.toString(2);  // 二进制
String hexStr = a.toString(16);   // 十六进制

优化

1. 不可变性

BigInteger 的每次操作都会返回一个新对象。如果需要频繁修改值,可以考虑复用变量以减少对象创建。

2. 注意内存消耗

超大整数会消耗较多内存。例如:

BigInteger big = new BigInteger("9".repeat(1000000)); // 100 万位数字

总结 

到此这篇关于Java之BigInteger类常用操作的文章就介绍到这了,更多相关Java BigInteger类常用操作内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文