java中求高精度除法,要求保留N位小數

求高精度除法,要求保留N位小數

題目要求

高精度除法,要求保留N位小數(四舍五入),並且當整數部分為0時去除0的顯示

import java.math.BigDecimal;
import java.util.Scanner;
public class BD
{
    public static void main(String[] args) 
    {
        Scanner scanner = new Scanner(System.in);
        while(scanner.hasNext())
       {
           BigDecimal a = scanner.nextBigDecimal();
           BigDecimal b = scanner.nextBigDecimal();
           int n = scanner.nextInt();
           System.out.println(a.divide(b, n, BigDecimal.ROUND_HALF_UP).toString().replaceFirst("^0*", ""));
       }
   }
}

java 大數處理和高精度小數處理(so easy)

試用范圍:當對數據處理時,最大的long型不能裝下,這時候就需要采用大數BigInteger來解決

簡單的例子:

package cn.hncu.BigNUM; 
import java.math.BigInteger; 
public class bigIntegerdemo { 
 public static void main(String[] args) {
   BigInteger sum=jc(100);//計算100的階乘是很大的數,long是超范圍的,所以采用Java 中的大數處理,BigInteger
   System.out.println(sum);
 } 
 private static BigInteger jc(int n) {
  BigInteger s=BigInteger.valueOf(1);//必須先變成bigInteger類型的才能進行運算
  for(int i=1;i<=n;i++){
   s=s.multiply(BigInteger.valueOf(i));//BigInteger的函數乘法也要用到函數
  }
  return s;  
 } 
}

若是采用double 值來操作,就會可能出現0.9999等一些近似值

部分簡單代碼

package cn.hncu.BigNUM; 
import java.math.BigDecimal; 
public class BigDecimal1 {
//高精度數處理
 public static void main(String[] args) {
   double sum=0;
   for(int i=0;i<10;i++){
    sum=sum+0.1;
   }//0.9999999999999999
   System.out.println(sum);//這樣的結果,是按著科學計算法來算,如double 四位,用二進制來表示,因為不可能完全能夠表示,所以去瞭近似值 
    add();
 }
 
 private static void add() {
  BigDecimal be =new BigDecimal(0);  
  for(int i=0;i<10;i++){
   be=be.add(new BigDecimal(0.1));//變成高精度後,會運算精準
  }
  System.out.println(be.doubleValue());//1.0  
 } 
}

以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。

推薦閱讀: