POJ1001

来源:互联网 发布:windows系统log 编辑:程序博客网 时间:2024/05/25 08:13

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