在很多算法中会用到绝对值,幂等的求值方法,虽然可以自己写一些方法来实现,但相对来说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);