ACM之Java速成(3)
ACM中Java.大数处理
先上个代码:
1 import java.math.*; 2 import java.util.*; 3 class Main{ 4 public static void main(String args[]){ 5 Scanner cin=new Scanner(System.in); 6 BigInteger a,b,t; 7 b=BigInteger.valueOf(17); 8 t=BigInteger.valueOf(0); 9 while(cin.hasNext()) 10 { 11 a=cin.nextBigInteger(); 12 if(a.compareTo(t)==0)break; 13 if(a.mod(b).compareTo(t)==0) 14 { 15 System.out.println("1"); 16 } 17 else System.out.println("0"); 18 } 19 } 20 }
BigInteger和BigDecimal可以说是acmer选择java的首要原因。
函数:add, subtract, divide, mod, compareTo等,其中加减乘除模都要求是BigInteger(BigDecimal)和BigInteger(BigDecimal)之间的运算,所以需要把int(double)类型转换为BigInteger(BigDecimal),用函数BigInteger.valueOf().
BigInteger
主要API
将字符串转换成BigInteger
BigInteger(String val)
将 BigInteger 的十进制字符串表示形式转换为 BigInteger。
BigInteger(String val, int radix)
将指定基数的 BigInteger 的字符串表示形式转换为 BigInteger。
BigInteger的加法
BigInteger
add(BigInteger val)
返回其值为 (this + val) 的 BigInteger。
BigInteger
and(BigInteger val)
返回其值为 (this & val) 的 BigInteger。
BigInteger的减法
BigInteger
subtract(BigInteger val)
返回其值为 (this - val) 的 BigInteger。
BigInteger的乘法
BigInteger
multiply(BigInteger val)
返回其值为 (this * val) 的 BigInteger。
大数求余:
BigInteger
mod(BigInteger m)
返回其值为 (this mod m) 的 BigInteger。
大数除法
BigInteger
divide(BigInteger val)
返回其值为 (this / val) 的 BigInteger。
其他一些
BigInteger
gcd(BigInteger val)
返回一个 BigInteger,其值是 abs(this) 和 abs(val) 的最大公约数。
BigInteger
max(BigInteger val)
返回此 BigInteger 和 val 的最大值。
BigInteger
min(BigInteger val)
返回此 BigInteger 和 val 的最小值。
BigDecimal类
主要API:
将字符串转换成BigDecimal
BigDecimal(String val)
将 BigDecimal 的字符串表示形式转换为 BigDecimal。
BigDecimal(String val, MathContext mc)
将 BigDecimal 的字符串表示形式转换为 BigDecimal,接受与 BigDecimal(String) 构造方法相同的字符串(按照上下文设置进行舍入)。
两个BigDecimal的相加
BigDecimal
add(BigDecimal augend)
返回一个 BigDecimal,其值为 (this + augend),其标度为 max(this.scale(), augend.scale())。
BigDecimal
add(BigDecimal augend, MathContext mc)
返回其值为 (this + augend) 的 BigDecimal(根据上下文设置进行舍入)。
两个BigDecimal的相减
BigDecimal
subtract(BigDecimal subtrahend)
返回一个 BigDecimal,其值为 (this - subtrahend),其标度为 max(this.scale(), subtrahend.scale())。
BigDecimal
subtract(BigDecimal subtrahend, MathContext mc)
返回其值为 (this - subtrahend) 的 BigDecimal(根据上下文设置进行舍入)。
两个BigDecimal的相除:
BigDecimal
divide(BigDecimal divisor)
返回一个 BigDecimal,其值为 (this / divisor),其首选标度为 (this.scale() - divisor.scale());如果无法表示准确的商值(因为它有无穷的十进制扩展),则抛出 ArithmeticException。
BigDecimal
divide(BigDecimal divisor, int roundingMode)
返回一个 BigDecimal,其值为 (this / divisor),其标度为 this.scale()。
BigDecimal
divide(BigDecimal divisor, int scale, int roundingMode)
返回一个 BigDecimal,其值为 (this / divisor),其标度为指定标度。
BigDecimal
divide(BigDecimal divisor, int scale, RoundingMode roundingMode)
返回一个 BigDecimal,其值为 (this / divisor),其标度为指定标度。
BigDecimal
divide(BigDecimal divisor, MathContext mc)
返回其值为 (this / divisor) 的 BigDecimal(根据上下文设置进行舍入)。
BigDecimal
divide(BigDecimal divisor, RoundingMode roundingMode)
返回一个 BigDecimal,其值为 (this / divisor),其标度为 this.scale()。
计算BigDecimal的N次幂
BigDecimal
pow(int n)
返回其值为 (thisn) 的 BigDecimal,准确计算该幂,使其具有无限精度。
BigDecimal
pow(int n, MathContext mc)
返回其值为 (thisn) 的 BigDecimal。
有关转换成字符串的方法
String
toEngineeringString()
返回此 BigDecimal 的字符串表示形式,需要指数时,则使用工程计数法。
String
toPlainString()
返回不带指数字段的此 BigDecimal 的字符串表示形式。
String
toString()
返回此 BigDecimal 的字符串表示形式,如果需要指数,则使用科学记数法。
大数相除:
1 import java.math.*; 2 import java.util.*; 3 class Main{ 4 public static void main(String args[]){ 5 Scanner cin=new Scanner(System.in); 6 BigInteger a,b,t; 7 b=BigInteger.valueOf(17); 8 t=BigInteger.valueOf(0); 9 while(cin.hasNext()) 10 { 11 a=cin.nextBigInteger(); 12 if(a.compareTo(t)==0)break; 13 if(a.mod(b).compareTo(t)==0) 14 { 15 System.out.println("1"); 16 } 17 else System.out.println("0"); 18 } 19 } 20 }
A+B problem IV
1 import java.math.*; 2 import java.util.*; 3 class Main{ 4 public static void main(String args[]){ 5 Scanner cin=new Scanner(System.in); 6 BigDecimal a,b,s,t; 7 t=BigDecimal.valueOf(0); 8 while(cin.hasNext()) 9 { 10 a=cin.nextBigDecimal(); 11 b=cin.nextBigDecimal(); 12 13 if(a.compareTo(t)==0&&b.compareTo(t)==0) 14 System.out.println("0"); 15 else 16 { 17 s=a.add(b); 18 System.out.println(s.stripTrailingZeros().toPlainString()); 19 } 20 } 21 } 22 }
高精度求幂
1 //高精度求幂 2 import java.util.*; 3 import java.io.*; 4 import java.math.*; 5 6 public class Main { 7 public static void main(String[] arg){ 8 Scanner cin=new Scanner(new BufferedInputStream(System.in)); 9 BigDecimal a; 10 for(;cin.hasNext();) 11 { 12 a=cin.nextBigDecimal(); 13 a=a.pow(cin.nextInt()).stripTrailingZeros(); 14 System.out.println(a.toPlainString().replaceAll("^0", "")); 15 } 16 } 17 }
未完待续,,,