Arrays类的常见操作
- 排序 :
sort()
- 查找 :
binarySearch()
- 比较:
equals()
- 填充 :
fill()
- 转列表:
asList()
- 转字符串 :
toString()
- 复制:
copyOf()
排序 : sort()
// *************排序 sort****************int a[] = { 1, 3, 2, 7, 6, 5, 4, 9 };// sort(int[] a)方法按照数字顺序排列指定的数组。Arrays.sort(a);System.out.println("Arrays.sort(a):");for (int i : a) {System.out.print(i);}// 换行System.out.println();// sort(int[] a,int fromIndex,int toIndex)按升序排列数组的指定范围int b[] = { 1, 3, 2, 7, 6, 5, 4, 9 };Arrays.sort(b, 2, 6);System.out.println("Arrays.sort(b, 2, 6):");for (int i : b) {System.out.print(i);}// 换行System.out.println();int c[] = { 1, 3, 2, 7, 6, 5, 4, 9 };// parallelSort(int[] a) 按照数字顺序排列指定的数组(并行的)。同sort方法一样也有按范围的排序Arrays.parallelSort(c);System.out.println("Arrays.parallelSort(c):");for (int i : c) {System.out.print(i);}// 换行System.out.println();// parallelSort给字符数组排序,sort也可以char d[] = { 'a', 'f', 'b', 'c', 'e', 'A', 'C', 'B' };Arrays.parallelSort(d);System.out.println("Arrays.parallelSort(d):");for (char d2 : d) {System.out.print(d2);}// 换行System.out.println();
在做算法面试题的时候,我们还可能会经常遇到对字符串排序的情况,Arrays.sort()
对每个字符串的特定位置进行比较,然后按照升序排序。
String[] strs = { "abcdehg", "abcdefg", "abcdeag" };
Arrays.sort(strs);
System.out.println(Arrays.toString(strs));//[abcdeag, abcdefg, abcdehg]
查找 : binarySearch()
// *************查找 binarySearch()****************char[] e = { 'a', 'f', 'b', 'c', 'e', 'A', 'C', 'B' };// 排序后再进行二分查找,否则找不到Arrays.sort(e);System.out.println("Arrays.sort(e)" + Arrays.toString(e));System.out.println("Arrays.binarySearch(e, 'c'):");int s = Arrays.binarySearch(e, 'c');System.out.println("字符c在数组的位置:" + s);
比较: equals()
// *************比较 equals****************char[] e = { 'a', 'f', 'b', 'c', 'e', 'A', 'C', 'B' };char[] f = { 'a', 'f', 'b', 'c', 'e', 'A', 'C', 'B' };/** 元素数量相同,并且相同位置的元素相同。 另外,如果两个数组引用都是null,则它们被认为是相等的 。*/// 输出trueSystem.out.println("Arrays.equals(e, f):" + Arrays.equals(e, f));
填充 : fill()
// *************填充fill(批量初始化)****************int[] g = { 1, 2, 3, 3, 3, 3, 6, 6, 6 };// 数组中所有元素重新分配值Arrays.fill(g, 3);System.out.println("Arrays.fill(g, 3):");// 输出结果:333333333for (int i : g) {System.out.print(i);}// 换行System.out.println();int[] h = { 1, 2, 3, 3, 3, 3, 6, 6, 6, };// 数组中指定范围元素重新分配值Arrays.fill(h, 0, 2, 9);System.out.println("Arrays.fill(h, 0, 2, 9);:");// 输出结果:993333666for (int i : h) {System.out.print(i);}
转列表 asList()
// *************转列表 asList()****************/** 返回由指定数组支持的固定大小的列表。* (将返回的列表更改为“写入数组”。)该方法作为基于数组和基于集合的API之间的桥梁,与Collection.toArray()相结合 。* 返回的列表是可序列化的,并实现RandomAccess 。* 此方法还提供了一种方便的方式来创建一个初始化为包含几个元素的固定大小的列表如下:*/List<String> stooges = Arrays.asList("Larry", "Moe", "Curly");System.out.println(stooges);
转字符串 toString()
// *************转字符串 toString()****************/** 返回指定数组的内容的字符串表示形式。*/char[] k = { 'a', 'f', 'b', 'c', 'e', 'A', 'C', 'B' };System.out.println(Arrays.toString(k));// [a, f, b, c, e, A, C, B]
复制 copyOf()
// *************复制 copy****************// copyOf 方法实现数组复制,h为数组,6为复制的长度int[] h = { 1, 2, 3, 3, 3, 3, 6, 6, 6, };int i[] = Arrays.copyOf(h, 6);System.out.println("Arrays.copyOf(h, 6);:");// 输出结果:123333for (int j : i) {System.out.print(j);}// 换行System.out.println();// copyOfRange将指定数组的指定范围复制到新数组中int j[] = Arrays.copyOfRange(h, 6, 11);System.out.println("Arrays.copyOfRange(h, 6, 11):");// 输出结果66600(h数组只有9个元素这里是从索引6到索引11复制所以不足的就为0)for (int j2 : j) {System.out.print(j2);}// 换行System.out.println();