• Java自学-数组 Arrays


    java.util.Arrays类常用方法

    Arrays是针对数组的工具类,可以进行 排序,查找,复制填充等功能。 大大提高了开发人员的工作效率。

    步骤 1 : 数组复制

    与使用System.arraycopy进行数组复制类似的, Arrays提供了一个copyOfRange方法进行数组复制。
    不同的是System.arraycopy,需要事先准备好目标数组,并分配长度。 copyOfRange 只需要源数组就就可以了,通过返回值,就能够得到目标数组了。
    除此之外,需要注意的是 copyOfRange 的第3个参数,表示源数组的结束位置,是取不到的

    import java.util.Arrays;
     
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
     
            // copyOfRange(int[] original, int from, int to)
            // 第一个参数表示源数组
            // 第二个参数表示开始位置(取得到)
            // 第三个参数表示结束位置(取不到)
            int[] b = Arrays.copyOfRange(a, 0, 3);
     
            for (int i = 0; i < b.length; i++) {
                System.out.print(b[i] + " ");
            }
     
        }
    }
    

    步骤 2 : 转换为字符串

    如果要打印一个数组的内容,就需要通过for循环来挨个遍历,逐一打印

    但是Arrays提供了一个toString()方法,直接把一个数组,转换为字符串,这样方便观察数组的内容

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            String content = Arrays.toString(a);
            System.out.println(content);
      
        }
    }
    

    步骤 3 : 排序

    在前面学习了 选择法排序 和 冒泡法排序,Arrays工具类提供了一个sort方法,只需要一行代码即可完成排序功能。

    排序

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            System.out.println("排序之前 :");
            System.out.println(Arrays.toString(a));
            Arrays.sort(a);
            System.out.println("排序之后:");
            System.out.println(Arrays.toString(a));
      
        }
    }
    

    步骤 4 : 搜索

    查询元素出现的位置
    需要注意的是,使用binarySearch进行查找之前,必须使用sort进行排序
    如果数组中有多个相同的元素,查找结果是不确定的

    搜索

     import java.util.Arrays;
         
        public class HelloWorld {
            public static void main(String[] args) {
                int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
         
                Arrays.sort(a);
         
                System.out.println(Arrays.toString(a));
                //使用binarySearch之前,必须先使用sort进行排序
                System.out.println("数字 62出现的位置:"+Arrays.binarySearch(a, 62));
            }
        }
    

    步骤 5 : 判断是否相同

    比较两个数组的内容是否一样
    第二个数组的最后一个元素是8,和第一个数组不一样,所以比较结果是false

    import java.util.Arrays;
     
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[] { 18, 62, 68, 82, 65, 9 };
            int b[] = new int[] { 18, 62, 68, 82, 65, 8 };
     
            System.out.println(Arrays.equals(a, b));
        }
    }
    

    步骤 6 : 填充

    使用同一个值,填充整个数组

    填充

    import java.util.Arrays;
      
    public class HelloWorld {
        public static void main(String[] args) {
            int a[] = new int[10];
      
            Arrays.fill(a, 5);
      
            System.out.println(Arrays.toString(a));
      
        }
    }
    

    练习二维数组排序

    (首先定义一个5X8的二维数组,然后使用随机数填充满。
    借助Arrays的方法对二维数组进行排序。
    参考思路:
    先把二维数组使用System.arraycopy进行数组复制到一个一维数组
    然后使用sort进行排序
    最后再复制回到二维数组。)

  • 相关阅读:
    在jsp页面如果运行时路径错误解决方法
    Maven实现ssm框架整合
    JS进阶(二)this指南——绑定了谁?
    防御性编程方法收集
    react将多个公共组件归成一类,方便调用
    初始化构建React+Ts项目时出现:Module build failed (from ./node_modules/css-loader/dist/cjs.js): CssSyntaxError
    Dva三种方式实现dispatch的Promise回调
    ES6多层解构
    ES6解构过程添加一个默认值和赋值一个新的值
    Antd-Pro2.0版本如何修改代理,让Mock变为真实服务器接口
  • 原文地址:https://www.cnblogs.com/jeddzd/p/11412460.html
Copyright © 2020-2023  润新知