zoukankan      html  css  js  c++  java
  • 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进行排序
    最后再复制回到二维数组。)

  • 相关阅读:
    pycharm破解补丁的使用
    C# 解析JSON格式数据
    LINQ to DataSet的DataTable操作
    日期格式化
    vue scoped原理
    vue父子组件生命周期执行顺序
    js判断同一天和同一周
    flex总结
    react-router v4 参数传递
    link标签rel="alternate"属性的作用及用法
  • 原文地址:https://www.cnblogs.com/jeddzd/p/11412460.html
Copyright © 2011-2022 走看看