java.util.Arrays 以及 java.util.Math

Arrays类

java.util.Array是一个与数组相关的工具类,里面提供了大量静态方法,用来实现数组常见的操作
	
	public static String toString(数组):将参数数组变成字符串(按照默认格式:[元素1,元素2,元素3])
	public static void sort(数组):按照默认升序对数组的元素进行排序。

* 备注:
	1. 如果是数组,sort默认按照升序从小到大
	2. 如果是字符串,sort默认按照字母升序
	3. 如果是自定义类型,那么这个自定义的类需要有Comparable或者Comparater接口的支持。(今后学习)
package cn.itcast.day08.demo04;

import java.util.Arrays;
import java.util.SplittableRandom;

public class Demo01Arrays {

    public static void main(String[] args) {
        int[] intArray = {10,20,30};
        //将int[]数组按照默认格式变成字符串
        String intStr = Arrays.toString(intArray);//调用toString方法将参数数组变成字符串
        System.out.println(intStr); //[10,20,30]

        int[] array1 = {21,3,19,9,20,};
        Arrays.sort(array1);  //sort方法直接对原来的数组进行排序,而不是产生一个新数组
        System.out.println(Arrays.toString(array1));	//调用静态方法

        String[] array2 = {"bbb","ccc","aaa"};
        Arrays.sort(array2);
        System.out.println(Arrays.toString(array2));	//[aaa,bbb,ccc]
    }
}
* 题目:
	请使用Arrays相关的API,将一个随机字符串中的所有字符升序排列,并倒序打印。
package cn.itcast.day08.demo04;

import java.util.Arrays;

public class Demo02ArraysPractise {

    public static void main(String[] args) {
        String str = "trcyvuybvggj234bhnkz";

        //如何进行升序排列?   sort
        //必须是一个数组,才能用Arrays.sort方法
        //String --> 数组,用toCharString
        char[] chars = str.toCharArray();
        Arrays.sort(chars);//对字符数组进行升序排列

        //需要倒序遍历
        for (int i = chars.length - 1; i >= 0; i--) {
            System.out.print(chars[i]);
        }
    }
}

Math类

* 题目:
	计算 -10.8 到 5.9 之间,绝对值大于 6 或者小于 2.1 的整数有多少个?

* 分析:
	1. 既然已经确定了范围,for循环
	2. 起点位置 -10.8 应该转换成为 -10 ,两种办法:
	   2.1 可以使用Math.ceil 方法,向上(向正方向)取整
	   2.2 强制转换成为int,自动舍弃所有小数位
	3. 每一个数字都是整数,所有步进表达式应该是 num++ ,这样每次都是 +1 的。
	4. 如何拿到绝对值:Math.abs方法。
	5. 一旦发现了一个数组,就需要让计数器 ++ 进行统计

备注:如果使用Math.ceil方法,-10.8 可以变成 -10.0 ,注意double也是可以进行++的
package cn.itcast.day08.demo04;

public class Demo04MathPractise {
    public static void main(String[] args) {
        double min = -10.8;
        double max = 5.9;
        //这样处理,变量i就是区间之内所有的整数
        int count = 0;
        for(int i = (int) min; i < max; i++){
            int abs = Math.abs(i);//绝对值
            if(abs > 6 || abs < 2.1) {
                System.out.println(i);
                count ++;
            }
        }
        System.out.println("总共有:" + count + "个符合要求的数字");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值