|
Set是一個(gè)接口,它有兩種實(shí)現(xiàn)分別是HashSet和TreeSet。 Set的特點(diǎn)是不保存重復(fù)的元素,它和數(shù)學(xué)概念上的集合相似,它支持交集、并集、差集操作。 本文將介紹HashSet和TreeSet使用的數(shù)據(jù)結(jié)構(gòu)以及兩種Set實(shí)現(xiàn)各自的應(yīng)用場(chǎng)景,然后介紹交集、并集、差集的使用。 HashSet vs TreeSetHashSet底層使用HashMap實(shí)現(xiàn),使用了數(shù)組和散列算法實(shí)現(xiàn),TreeSet使用TreeMap實(shí)現(xiàn),使用了紅黑樹數(shù)據(jù)結(jié)構(gòu)。關(guān)于HashMap和TreeMap實(shí)現(xiàn)原理可以翻閱前面的文章。HashSet的優(yōu)點(diǎn)是查找速度快,缺點(diǎn)是不能順序遍歷Set中的元素,TreeSet的優(yōu)點(diǎn)是可以順序遍歷Set中的元素,缺點(diǎn)是查找速度比HashSet稍慢,實(shí)際應(yīng)用中優(yōu)先使用HashSet,有排序需求時(shí)才考慮使用TreeSet。 交集假設(shè)有集合A和集合B,所有既屬于A又屬于B的元素組成的集合,稱為集合A于集合B的交集。Set中交集使用retainAll方法實(shí)現(xiàn), 示例代碼如下: 并集假設(shè)有集合A和集合B,把A和B中的所有元素合并在一起組成的集合,稱為集合A和集合B的并集。Set中并集使用addAll方法實(shí)現(xiàn),示例代碼如下: 差集假設(shè)有集合A和集合B,所有屬于A且不屬于B的元素組成的集合,稱為集合A和集合B的差集。Set中 差集使用removeAll方法實(shí)現(xiàn),示例代碼如下: 最后交集、并集、差集使用的方法都來自Collection接口,那么實(shí)現(xiàn)了Collection的其它非Set容器是否也可以進(jìn)行數(shù)學(xué)集合操作?嚴(yán)格意義上來說只有Map和Set可以用來實(shí)現(xiàn)數(shù)學(xué)集合操作,因?yàn)閿?shù)學(xué)集合沒有重復(fù)元素,Map和Set不能包含重復(fù)的鍵或元素,而數(shù)組、鏈表數(shù)據(jù)結(jié)構(gòu)可以包含重復(fù)的元素,所以只能使用Map和Set來處理數(shù)學(xué)集合操作。Map是一個(gè)鍵值對(duì)集合,如果使用Map進(jìn)行數(shù)學(xué)集合操作,那么我們往Map中添加元素時(shí)除了鍵以外還需要指定一個(gè)值。Set底層是對(duì)Map的封裝,它隱藏了Map中鍵值對(duì)的值,我們只需關(guān)注鍵,所以實(shí)際應(yīng)用中數(shù)學(xué)集合操作只用Set處理。 |
|
|