版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u011815404/article/details/82586983
【概述】
在 C++ 中数据类型的长度最多能到 64 位,一旦超出这个位数,就要用数组进行模拟计算,即高精度算法
而在 Java 中有两个类:BigInteger、BigDecimal 分别表示大整数类和大浮点数类,其理论上能表示无限大的数,只要计算机内存足够大。
这两个类都在 java.math.* 包中,因此每次使用必须在开头处引用该包。
【常量】
BigInteger 的 ONE、ZERO、TEN 分别代表 1、0、10
BigInteger.ZERO //大整数0
BigInteger.ONE //大整数1
BigInteger.TEN //大整数10
而在 BigDecimal 中除了以上三个常量外还有8个关于舍入的常量:ROUND_UP、ROUND_DOWN、ROUND_CEILING、ROUND_FLOOR、ROUND_HALF_UP、ROUND_HALF_DOWN、ROUND_HALF_EVEN、ROUND_UNNECESSARY。
【声明赋值】
基本类型的定义:
BigInteger name = new BigInteger(String) ;//参数是字符串
BigInteger name = BigInteger.valueOf(123); //参数是 int、long
BigDecimal name = new BigDecimal(String) ;//参数是字符串
BigDecimal name = BigDecimal.valueOf(123.45); //参数是 float、double
【输入框架】
Scanner input = new Scanner(System.in);
while(input.hasNext()){ //等同 !=EOF
BigInteger a;
a = input.BigInteger();
System.out.println(a);
}
【基本用法】
1.四则运算
BigInteger a = new BigInteger.valueOf(10);
BigInteger b = new BigInteger.valueOf(10);
a.add(b); //加法
a.subtract(b); //减法
a.divide(b); //除法
a.multiply(b); //乘法
2.比较大小
BigInteger a = new BigInteger.valueOf(10);
BigInteger b = new BigInteger.valueOf(10);
a.equals(b); //如果a、b相等返回true否则返回false
a.comareTo(b); //a小于b返回-1,等于返回0,大于返回1
3.常用方法
BigInteger a = new BigInteger.valueOf(10);
BigInteger b = new BigInteger.valueOf(15);
a.mod(b); //求余
a.gcd(b); //求最大公约数
a.max(b); //求最大值
a.min(b); //求最小值