java arrays.sqrt_Java基础之:Math & Arrays & System

Java基础之:Math & Arrays & System

Math

Math 类包含用于执行基本数学运算的方法,如初等指数、对数、平方根和三角函数。

方法介绍:

1.abs 绝对值

2.pow 求幂

3.ceil 向上取整,返回>=该参数的最小整数;

4.floor 向下取整,返回<=该参数的最大整数

5.round 四舍五入 Math.floor(该参数+0.5)

6.sqrt 求开方

7.random 返回随机数【0——1) ,重点!!

package class_Math;public class ClassTest01 {​ public static void main(String[] args) { //1.abs 绝对值 int abs = Math.abs(9); System.out.println(abs); //2.pow 求幂 double pow = Math.pow(-3.5, 4); System.out.println(pow); //3.ceil 向上取整,返回>=该参数的最小整数; double ceil = Math.ceil(-3.0001); System.out.println(ceil); //4.floor 向下取整,返回<=该参数的最大整数 double floor = Math.floor(-4.999); System.out.println(floor); //5.round 四舍五入 Math.floor(该参数+0.5) long round = Math.round(-5.001); System.out.println(round); //6.sqrt 求开方 double sqrt = Math.sqrt(-9.0); System.out.println(sqrt); //7.random 返回随机数【0——1) //[a-b]:int num = (int)(Math.random()*(b-a+1)+a) double random = Math.random(); System.out.println(random); //小技巧:获取一个 a-b 之间的一个随机整数 int a = (int)(Math.random()*(15-7+1)+7); System.out.println(a); /* * 理解: * 1.Math.random() 是 [0,1)的随机数 * 2.(Math.random()*(15-7+1) 就是[0,9) * 3.Math.random()*(15-7+1)+7 就是[7,16) * 4.(int)取整就是 [7,15] ,即[a,b]之间的随机整数 */ }}

Arrays

Arrays里面包含了一系列静态方法,用于管理或操作数组(比如排序和搜索)。

Arrays排序sort方法

package class_Arrays;​import java.util.Arrays;import java.util.Comparator;​public class ClassTest01 { public static void main(String[] args) { Integer[] arr = { 25, 35, 11, 32, 98, 22 };// Arrays.sort(arr); //默认小到大排序 System.out.println(Arrays.toString(arr));​ // 使用匿名内部类重写compare方法,实现从大到小排序 Arrays.sort(arr, new Comparator() {​ @Override public int compare(Integer o1, Integer o2) { if (o1 > o2) { return -1; } else if (o1 < o2) { return 1; } else { return 0; } } }); System.out.println(Arrays.toString(arr)); }}​//自写一个Arrays中的sort方法 体会为什么通过重写之后,匿名内部类动态绑定机制改变了排序方式class MyArrays { @SuppressWarnings("unchecked") public static void sort(Integer[] arr,Comparator c) { Integer temp = 0;// 自动装箱 for (int i = 0; i < arr.length; i++) { for (int j = 0; j < arr.length - 1 - i; j++) { if (c.compare(arr[j] , arr[j + 1]) > 0) { temp = arr[j]; arr[j] = arr[j + 1]; arr[j + 1] = temp; } } } } public static void main(String[] args) { Integer[] arr = { 25, 35, 11, 32, 98, 22 };// MyArrays.sort(arr);//不添加 Comparator接口对象为参数,就是简单的冒泡排序方法 //添加匿名内部类对象为参数,就可以改变排序方式。用此方法可以很灵活的使用排序。 MyArrays.sort(arr, new Comparator() {​ @Override public int compare(Integer o1, Integer o2) { //通过返回值的正负来控制,升序还是降序 //只有当返回值为1时,才会发生交换。例如这里,o1 < o2时返回1 ,进行交换 //也就是需要前面的数,比后面的数大,即降序 if (o1 > o2) { return -1; } else if (o1 < o2) { return 1; } else { return 0; } } }); System.out.println(Arrays.toString(arr)); }}

Arrays查找binarySearch方法及其他常用方法

package class_Arrays;​import java.util.List;import java.util.Arrays;​public class ClassTest02 {​ public static void main(String[] args) { //随机生成数组,并排序 Integer[] arr = new Integer[10];// for (int i = 0; i < arr.length; i++) {// arr[i] = (int)(Math.random()*100) + 1 ;// }// Arrays.sort(arr); arr = new Integer[]{16, 28, 41, 51, 62, 67, 67, 86, 90, 93}; System.out.println(Arrays.toString(arr)); // binarySearch 通过二分搜索法进行查找,要求必须排好序 int index = Arrays.binarySearch(arr, 55); //返回 -5 (55在51和62之间) //找到则返回下标,若没有找到则返回-(low + 1)。即此数在数组中应该在的位置的下标 + 1,例: //{1,3,5,9,10},此数组中找2,没有找到则返回-2,因为2本来在1和3的中间。下.........

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值