POJ1001

问题描述:对数值很大、精度很高的数进行高精度计算是一类十分常见的问题。比如,对国债进行计算就是属于这类问题。
现在要你解决的问题是:对一个实数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);
        }
    }
}

你可能感兴趣的:(【ACM】➣,poj)