Math类的常用方法--田小江

在很多算法中会用到绝对值,幂等的求值方法,虽然可以自己写一些方法来实现,但相对来说Math类的这些方法可以更好更严谨的操作数据。
所以总结一下Math类的常用方法。

  • 绝对值:Math.abs(a);
    (a可以是int、float、double类型,相对应的返回值也为int、float、double)
public class MathJueDuiZhi {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        double b = scan.nextDouble();
        double a = Math.abs(b);
        System.out.println(b+"的绝对值是"+a);
    }
}
  • 求幂(某一个数的n次方):Math.pow(double a,double b);
    求a的b次方(b个a相乘)。
public class MathQiuMi {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        int num = scan.nextInt();
        System.out.println("求它的几次方:");
        int a = scan.nextInt();
        double b = Math.pow(num, a);
        System.out.println(num + "的" + a + "次方的值为:" + b);
    }
}
  • e的N次方的值:Math.exp(double a)
public class MathENCiFang {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        double a = scan.nextDouble();
        double b = Math.exp(a);
        System.out.println("e的" + a + "次方是:" + b);
    }
}
  • e的N次方-1的值:Math.Math.expm1(double a)
public class MathENCiFang {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        double a = scan.nextDouble();
        double b = Math.expm1(a);
        System.out.println("e的" + a + "次方-1是:" + b);
    }
}
  • 立方根:Math.cbrt(double a);
public class MathLiFangGen {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        double a = scan.nextDouble();
        double b = Math.cbrt(a);
        System.out.println(a + "的立方根为:" + b);
    }
}
  • 返回不小于a的最小整数:Math.ceil(double a);
public class MathZuiXiaoZhengShu {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        double a = scan.nextDouble();
        double b = Math.ceil(a);
        System.out.println("不小于" + a + "的最小整数为:" + b);
    }
}
  • 返回不大于a的最大整数:Math.floor(double a);
public class MathZuiDaZhengShu {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        System.out.println("输入一个数!");
        double a = scan.nextDouble();
        double b = Math.floor(a);
        System.out.println("不大于" + a + "的最大整数为:" + b);
    }
}
  • 返回等于或小于代数商的最大整数值:Math.floorDiv(a, b);
    (a,b可以为long或者int型,a是除数,b是被除数)
public class MathFloorDiv {
public static void main(String[] args) {
    Scanner scan = new Scanner(System.in);
    int a = scan.nextInt();
    int b = scan.nextInt();
    int c = Math.floorDiv(a, b);
    System.out.println(a+"/"+b+"的最大整数值是:"+c);
}
}

输入a=12,b=5
输出结果:a/5的最大整数值是:2

  • 余数:Math.floorDiv(a, b);
public class MathFloorMod {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int a = scan.nextInt();
        int b = scan.nextInt();
        int c = Math.floorMod(a, b);
        System.out.println(a+"%"+b+"=:"+c);
    }
}

输入:a=9,b=5
输出结果:9%5=4

  • 两个参数平方值之和的平方根:Math.hypot(double a, double b);
public class MathHypot {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        double a = scan.nextDouble();
        double b = scan.nextDouble();
        double c = Math.hypot(5.6, 6.5);
        System.out.println(a+"和"+b+"的平方值之和的平方根为:"+c);
    }
}

输入:a=3,b=4
输出结果:3和4的平方值之和的平方根为5

  • 返回较小的数:Math.min(a.b) 如:Math.min(1, 2) =1
    返回较大的数:Math.max(a.b) 如:Math.max(1, 2) = 2
  • 返回0,1之间的一个随机数:Math.random();
  • 余弦函数:Math.cos(a);
  • 反余弦函数:Math.acos(a);
  • 双曲余弦值:Math.cosh(a);

  • 正弦函数:Math.sin(a);
  • 反正弦函数:Math.asin(a);

  • 正切函数:Math.tan(a);
  • 反正切函数:Math.atan(a);
  • 商的反正切函数:Math.atan2(a,b);

  • 两个数字相加:Math.addExact(a,b);
    (a,b可以为int或long型)

  • Math.copySign()方法将第一个参数的标记设置为第二个参数的标记。

  • Math.decrementExact(int a);无溢出运算,具体用法还不清楚。
    Math.getExponent(double/floor a);
点赞