簡體   English   中英

Collections.binarySearch()與List indexOf()

[英]Collections.binarySearch() vs. List indexOf()

我有一個超過37K項的列表,我已經實現了hashCode()equals() ,所以我想我們想知道Collections.binarySearch()可以幫助提高性能,並且比indexOf()方法更快。

如果你的集合是排序的, binarySearch()將是O(log n)而不是indexOf()的O(n),你肯定會看到一個改進。

為了使binarySearch()起作用,必須對列表進行排序。 equals()和hashCode()與排序無關。 您的對象需要是可比較的,或者您必須擁有相關的比較器。 無論哪種方式,您必須先排序列表。

是的,假設列表已排序,那么與indexOf()相比,您可能會從binarySearch()獲得更好的性能。

使用HashSet可以獲得更好的性能。 但這將占用更多空間。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM