亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么有效地檢查數組是否包含Java中的值

發布時間:2022-02-28 11:08:44 來源:億速云 閱讀:140 作者:小新 欄目:開發技術

這篇文章主要介紹怎么有效地檢查數組是否包含Java中的值,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

1. 檢查數組是否包含值的四種不同方法

1) 使用List

public static boolean useList(String[] arr, String targetValue) {	return Arrays.asList(arr).contains(targetValue);
}

2) 使用 Set:

public static boolean useSet(String[] arr, String targetValue) {
	Set<String> set = new HashSet<String>(Arrays.asList(arr));	return set.contains(targetValue);
}

3)使用一個簡單的循環:

public static boolean useArraysBinarySearch(String[] arr, String targetValue) {	
	int a =  Arrays.binarySearch(arr, targetValue);	if(a > 0)		return true;	elsereturn false;
}

4) 使用 Arrays.binarySearch()

public static boolean useArraysBinarySearch(String[] arr, String targetValue) {	
	int a =  Arrays.binarySearch(arr, targetValue);	if(a > 0)		return true;	elsereturn false;
}

2. 時間復雜度

可以使用以下代碼來測量大致的時間成本。基本思想是搜索大小為 5、1k、10k 的數組。該方法可能不精確,但其思想清晰而簡單。

public static void main(String[] args) {
	String[] arr = new String[] {  "CD",  "BC", "EF", "DE", "AB"};
 	//use listlong startTime = System.nanoTime();	for (int i = 0; i < 100000; i++) {
		useList(arr, "A");
	}	long endTime = System.nanoTime();	long duration = endTime - startTime;
	System.out.println("useList:  " + duration / 1000000);
 	//use set
	startTime = System.nanoTime();	for (int i = 0; i < 100000; i++) {
		useSet(arr, "A");
	}
	endTime = System.nanoTime();
	duration = endTime - startTime;
	System.out.println("useSet:  " + duration / 1000000);
 	//use loop
	startTime = System.nanoTime();	for (int i = 0; i < 100000; i++) {
		useLoop(arr, "A");
	}
	endTime = System.nanoTime();
	duration = endTime - startTime;
	System.out.println("useLoop:  " + duration / 1000000);

結果:

useList:  13useSet:  72useLoop:  5

使用更大的數組 (1k):

String[] arr = new String[1000];
 
Random s = new Random();for(int i=0; i< 1000; i++){
	arr[i] = String.valueOf(s.nextInt());
}

結果:

useList:  112
useSet:  2055
useLoop:  99
useArrayBinary:  12

使用更大的數組(10k):

String[] arr = new String[10000];
 
Random s = new Random();
for(int i=0; i< 10000; i++){
	arr[i] = String.valueOf(s.nextInt());
}

結果:

useList:  1590useSet:  23819useLoop:  1526useArrayBinary:  12

顯然,使用簡單的循環方法比使用任何集合更有效。很多開發人員使用第一種方法,但效率低下。將數組推送到另一個集合需要在對集合類型執行任何操作之前遍歷所有元素以讀取它們。

如果使用 Arrays.binarySearch() 方法,則必須對數組進行排序。在這種情況下,數組未排序,因此不應使用它。

實際上,如果您需要有效地檢查某個值是否包含在某個數組/集合中,排序列表或樹可以在 O(log(n)) 中完成,或者 hashset 可以在 O(1) 中完成。

以上是“怎么有效地檢查數組是否包含Java中的值”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

玉林市| 临沭县| 虹口区| 铁岭县| 壤塘县| 武邑县| 香格里拉县| 周至县| 青岛市| 南投县| 长沙县| 桃园市| 齐齐哈尔市| 大石桥市| 雷山县| 西乌珠穆沁旗| 新巴尔虎右旗| 红河县| 元江| 鄂州市| 玛纳斯县| 大埔县| 水城县| 静海县| 原平市| 庄河市| 宜兰市| 兴仁县| 蓬莱市| 呼和浩特市| 二手房| 江达县| 伊金霍洛旗| 屏东县| 胶州市| 娄烦县| 兴文县| 巴彦淖尔市| 精河县| 华容县| 玉树县|