poj 1131 进制转换 Java高精度

题目:http://poj.org/problem?id=1131
题意:
给出一个0-1之间的八进制小数,要求转换成10进制小数。
分析:
因为There is no limit on k,所以要用高精度了。

import java.io.*;
import java.math.*;
import java.util.*;
public class Main{
    static public void main(String[] args) {

        Scanner cin=new Scanner(new BufferedInputStream(System.in));
        BigDecimal eight=new BigDecimal(8);
        while(cin.hasNext()){
            String a=cin.nextLine();
            BigDecimal ans=new BigDecimal(0);
            BigDecimal tmp=new BigDecimal(1);
            for(int i=2;i<a.length();i++){
                tmp=tmp.divide(eight);
                ans=ans.add(new BigDecimal(a.charAt(i)-'0').multiply(tmp));
            }
            System.out.println(a+" [8] = "+ans.stripTrailingZeros().toPlainString()+" [10]");
        }
    }
}
原文地址:https://www.cnblogs.com/01world/p/5651233.html