有关Java大浮点数BigDecimal的简单使用[连续更新]

简介: Java大浮点数BigDecimal的精度可以认为是无限的BigDecimal 里面的pow()的复杂度是快速幂的复杂度logBigDecimal.pow() 里面的参数是一个整数,BigDecimal的构造方式和BigInteger 类似BigDecimal 保留小数的方法比较多,一般情况下下保留到小数点后x(int)位的情况下,可以调用方法setScale在多次操作之后,数据的长度可能比较大,所以说运算起来就会减慢速度,所以说可能会导致TLE
  1. Java大浮点数BigDecimal的精度可以认为是无限的
  2. BigDecimal 里面的pow()的复杂度是快速幂的复杂度log
  3. BigDecimal.pow() 里面的参数是一个整数,
  4. BigDecimal的构造方式和BigInteger 类似
  5. BigDecimal 保留小数的方法比较多,一般情况下下保留到小数点后x(int)位的情况下,可以调用方法setScale
  6. 在多次操作之后,数据的长度可能比较大,所以说运算起来就会减慢速度,所以说可能会导致TLE


某示例代码如下:

import java.math.BigDecimal;
import java.math.BigInteger;
import java.math.RoundingMode;
import java.util.Scanner;
public class Main {
    public static int a[] = new int[100007];
    public static BigDecimal b[] = new BigDecimal[100007];
    public static void main(String[] args) {
        Scanner cin =  new Scanner(System.in);
        int n = cin.nextInt();
        for(int i=1;i<=n;i++) a[i] = cin.nextInt();
        BigDecimal e = BigDecimal.valueOf(Math.E);
        BigDecimal sum = BigDecimal.valueOf(0.0);
        for(int i=1;i<=n;i++){
            sum = sum.add(e.pow(a[i]));
        }
      sum = sum.setScale(10, RoundingMode.HALF_UP);///小数点保留到十位,舍入方式是四舍五入
        for(int i=1;i<=n;i++){
            b[i] = e.pow(a[i]).divide(sum);
        }
        for(int i=1;i<=n;i++){
            System.out.print(b[i].setScale(10));
            if(i != n) System.out.print(" ");
        }
    }
}
/**
 5
 * **/



目录
相关文章
|
Java
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
【Java】如果一个集合中类型是String如何使用拉姆达表达式 进行Bigdecimal类型计算?
328 0
|
7月前
|
存储 人工智能 Java
Java 的 BigDecimal 是什么?
`BigDecimal` 是 Java 中用于高精度浮点数运算的类,位于 `java.math` 包。它支持精确的数学运算(加、减、乘、除等),并可设置精度和舍入模式,适用于财务和科学计算场景。其主要特点是高精度、不可变性和灵活的运算控制。相比 `float` 和 `double`,`BigDecimal` 能避免二进制表示带来的精度丢失问题。推荐通过字符串或 `BigDecimal.valueOf` 方法创建对象以确保精度。
149 0
【Java】Math、System、RunTime、BigDecimal类常用方法
【Java】Math、System、RunTime、BigDecimal类常用方法
127 0
|
11月前
|
Java
Java项目中高精度数值计算:为何BigDecimal优于Double
在Java项目开发中,涉及金额计算、面积计算等高精度数值操作时,应选择 `BigDecimal` 而非 `Double`。`BigDecimal` 提供任意精度的小数运算、多种舍入模式和良好的可读性,确保计算结果的准确性和可靠性。例如,在金额计算中,`BigDecimal` 可以精确到小数点后两位,而 `Double` 可能因精度问题导致结果不准确。
229 1
|
12月前
|
安全 Java
java BigDecimal 的赋值一个常量
在 Java 中,`BigDecimal` 是一个用于精确计算的类,特别适合处理需要高精度和小数点运算的场景。如果你需要给 `BigDecimal` 赋值一个常量,可以使用其静态方法 `valueOf` 或者直接通过字符串构造函数。 以下是几种常见的方法来给 `BigDecimal` 赋值一个常量: ### 使用 `BigDecimal.valueOf` 这是推荐的方式,因为它可以避免潜在的精度问题。 ```java import java.math.BigDecimal; public class BigDecimalExample { public static void
301 4
|
安全 Java
12 Java常用类(二)(String类+时间类+BigDecimal类等等)
12 Java常用类(二)(String类+时间类+BigDecimal类等等)
106 2
深入了解Java中的BigDecimal类及其方法
深入了解Java中的BigDecimal类及其方法
282 1
|
安全 Java
java中BigDecimal详解
java中BigDecimal详解
|
算法 Java API
java BigDecimal使用详细介绍
java BigDecimal使用详细介绍
325 0
java BigDecimal使用详细介绍
|
存储 Java
Java中BigDecimal怎样取反
在上述示例中,`number.negate()`会将BigDecimal对象 `number`的值取反,并将结果存储在新的BigDecimal对象 `negated`中。
333 0