1. 程式人生 > >JavaSE011_陣列之常用工具類Arrays

JavaSE011_陣列之常用工具類Arrays

java.util.Arrays類能方便地運算元組,它提供的所有方法都是靜態的(static修飾的方法可以直接通過類名呼叫,即類方法)。具有以下功能:
1、給陣列賦值:通過fill方法。
2、對陣列排序:通過sort方法,按升序。
3、比較陣列:通過equals方法比較陣列中元素值是否相等。
4、查詢陣列元素:通過binarySearch方法能對排序好的陣列進行二分查詢法操作。

例項程式碼如下:

import java.util.Arrays;

public class TestArrays {
	public static void output(int[] array) {
		if (array != null) {
			for (int i = 0; i < array.length; i++) {
				System.out.print(array[i] + " ");
			}
		}
		System.out.println();
	}

	public static void main(String[] args) {
		int[] array = new int[5];
		// 填充陣列
		Arrays.fill(array, 5);
		System.out.println("填充陣列:Arrays.fill(array, 5):");
		TestArrays.output(array);

		// 將陣列的第2和第3個元素賦值為8
		Arrays.fill(array, 2, 4, 8);
		System.out.println("將陣列的第2和第3個元素賦值為8:Arrays.fill(array, 2, 4, 8):");
		TestArrays.output(array);

		int[] array1 = { 7, 8, 3, 2, 12, 6, 3, 5, 4 };
		// 對陣列的第2個到第6個進行排序進行排序
		Arrays.sort(array1, 2, 7);
		System.out.println("對陣列的第2個到第6個元素進行排序進行排序:Arrays.sort(array,2,7):");
		TestArrays.output(array1);

		// 對整個陣列進行排序
		Arrays.sort(array1);
		System.out.println("對整個陣列進行排序:Arrays.sort(array1):");
		TestArrays.output(array1);

		// 比較陣列元素是否相等
		System.out.println("比較陣列元素是否相等:Arrays.equals(array, array1):" + "\n" + Arrays.equals(array, array1));
		int[] array2 = array1.clone();
		System.out.println("克隆後陣列元素是否相等:Arrays.equals(array1, array2):" + "\n" + Arrays.equals(array1, array2));

		// 使用二分搜尋演算法查詢指定元素所在的下標(必須是排序好的,否則結果不正確)
		Arrays.sort(array1);
		System.out.println("元素3在array1中的位置:Arrays.binarySearch(array1, 3):" + "\n" + Arrays.binarySearch(array1, 3));
		// 如果不存在就返回負數
		System.out.println("元素9在array1中的位置:Arrays.binarySearch(array1, 9):" + "\n" + Arrays.binarySearch(array1, 9));
	}
}
輸出結果為:

填充陣列:Arrays.fill(array, 5):
5 5 5 5 5 
將陣列的第2和第3個元素賦值為8:Arrays.fill(array, 2, 4, 8):
5 5 8 8 5 
對陣列的第2個到第6個元素進行排序進行排序:Arrays.sort(array,2,7):
7 8 2 3 3 6 12 5 4 
對整個陣列進行排序:Arrays.sort(array1):
2 3 3 4 5 6 7 8 12 
比較陣列元素是否相等:Arrays.equals(array, array1):
false
克隆後陣列元素是否相等:Arrays.equals(array1, array2):
true
元素3在array1中的位置:Arrays.binarySearch(array1, 3):
1
元素9在array1中的位置:Arrays.binarySearch(array1, 9):
-9

import java.util.*;

public class Arrays2 {
	public static void main(String[] args) {
		// 定義一個a陣列
		int[] a = new int[] { 3, 4, 5, 6 };
		// 定義一個a2陣列
		int[] a2 = new int[] { 3, 4, 5, 6 };
		// a陣列和a2陣列的長度相等,每個元素依次相等,將輸出true
		System.out.println("a陣列和a2陣列是否相等:" + Arrays.equals(a, a2));
		// 通過複製a陣列,生成一個新的b陣列
		int[] b = Arrays.copyOf(a, 6);
		System.out.println("a陣列和b陣列是否相等:" + Arrays.equals(a, b));
		// 輸出b陣列的元素,將輸出[3, 4, 5, 6, 0, 0]
		System.out.println("b陣列的元素為:" + Arrays.toString(b));
		// 將b陣列的第3個元素(包括)到第5個元素(不包括)賦為1
		Arrays.fill(b, 2, 4, 1);
		// 輸出b陣列的元素,將輸出[3, 4, 1, 1, 0, 0]
		System.out.println("b陣列的元素為:" + Arrays.toString(b));
		// 對b陣列進行排序
		Arrays.sort(b);
		// 輸出b陣列的元素,將輸出[0, 0, 1, 1, 3, 4]
		System.out.println("b陣列的元素為:" + Arrays.toString(b));
	}
}
輸出結果為:

a陣列和a2陣列是否相等:true
a陣列和b陣列是否相等:false
b陣列的元素為:[3, 4, 5, 6, 0, 0]
b陣列的元素為:[3, 4, 1, 1, 0, 0]
b陣列的元素為:[0, 0, 1, 1, 3, 4]