问题描述:对数值很大、精度很高的数进行高精度计算是一类十分常见的问题。比如,对国债进行计算就是属于这类问题。
现在要你解决的问题是:对一个实数R( 0.0 < R < 99.999 ),要求写程序精确计算 R 的 n 次方(Rn),其中n 是整数并且 0 < n <= 25。
解题思路:对于求高精度幂问题,可以采用Java中的大小数乘法BigDecimal
类来处理,从而绕开了C语言中对大数据的复杂计算
code(Java)
import java.math.BigDecimal;
import java.util.Scanner;
public class Main{
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
while(in.hasNext()){
BigDecimal a = in.nextBigDecimal();
a = a.stripTrailingZeros();
int b = in.nextInt();
String s;
BigDecimal c = a.pow(b);
if(c.compareTo(BigDecimal.ONE) == -1)
s = c.toPlainString().replaceFirst("0", "");
else
s = c.toPlainString();
System.out.println(s);
}
}
}