Java求兩集合的交集、并集、差集實(shí)例
一、內(nèi)置函數(shù)實(shí)現(xiàn)
- removeAll方法:從list中刪除指定集合中包含的所有元素。
- retainAll方法:從list中刪除指定集合中不包含的所有元素。
- addAll方法:用來(lái)向Set集合添加另一個(gè)集合對(duì)象所包含的所有內(nèi)容。
public class CollectionTest {
public static void main(String[] args) {
List<String> list1 = new ArrayList<>();
List<String> list2 = new ArrayList<>();
list1.add("a");
list1.add("b");
list1.add("c");
list2.add("b");
list2.add("e");
list2.add("d");
//求交集
list1.retainAll(list2);
System.out.println(list1.toString()); // b
//求并集
list1.removeAll(list2);
list1.addAll(list2);
System.out.println(list1.toString()); // a c b e d
//求差集(list1有而list2沒有)
list1.removeAll(list2); // a c
}
}二、for循環(huán)遍歷實(shí)現(xiàn) 求兩個(gè)集合的交集
利用集合的contains方法,來(lái)對(duì)比第二個(gè)集合中是否存在相同的元素的方法,同時(shí)將交集結(jié)果返回。時(shí)間復(fù)雜度是O(n)。
contains方法:用于判斷l(xiāng)ist集合是否包含某個(gè)元素。
public List<Object> intersectionForList_1(List<Object> arr1, List<Object> arr2) {
long startTime = System.currentTimeMillis();
List<Object> result = new ArrayList<>();
for (Object arr : arr1) {
if (arr2.contains(arr)) {
result.add(arr);
}
}
long endTime = System.currentTimeMillis();
log.info("intersectionForList_1:" + (endTime - startTime));
return result;
}三、使用Java 8 Stream API 求兩個(gè)集合的交集
首先把兩個(gè)集合轉(zhuǎn)換成Stream,然后使用filter()方法篩選出交集元素,最后把結(jié)果轉(zhuǎn)換成集合。 時(shí)間復(fù)雜度是O(n)。
.stream().filter()方法:來(lái)篩選出滿足條件的對(duì)象,最終返回的篩選過(guò)后的列表。
Collectors.toList()和Collectors.toSet()方法都是將map后的stream轉(zhuǎn)換為一個(gè)列表對(duì)象,toSet()會(huì)去重重復(fù)的對(duì)象
Set<Integer> set1 = new HashSet<>(); set1.add(1); set1.add(2); set1.add(3); set1.add(4); Set<Integer> set2 = new HashSet<>(); set2.add(3); set2.add(4); set2.add(5); Set<Integer> intersection = set1.stream().filter(set2::contains).collect(Collectors.toSet()); System.out.println(intersection); // 輸出 [3, 4]
四、使用迭代器求兩個(gè)集合的交集
public List<Object> intersectionForList_2(List<Object> arr1, List<Object> arr2) {
List<Object> resultList = new ArrayList<>();
List<Object> maxList;
List<Object> minList;
if (arr1.size()>arr2.size()){
maxList = arr1;
minList = arr2;
}else {
maxList = arr2;
minList = arr1;
}
Iterator<Object> iterator = maxList.iterator();
while (iterator.hasNext()){
Object next = iterator.next();
if (minList.contains(next)){
resultList.add(next);
}
}
return resultList;
}五、使用map 求兩個(gè)集合的交集
首先將list集合中的元素依次存入一個(gè)map中去,然后再以map的get方法來(lái)判斷是否存在這樣的元素。
這種方法的效率最高,在10萬(wàn)條數(shù)據(jù)的測(cè)試下,這種方法耗時(shí)僅僅在十幾毫秒,而其他方法在將近一百多毫秒。
在百萬(wàn)條數(shù)據(jù)進(jìn)行對(duì)比處理的時(shí)候,使用map特性的方法時(shí)間消耗大概在40毫秒左右,但是其他方法要將近10秒鐘,
所以在對(duì)于大量數(shù)據(jù)的處理過(guò)程中,還是非常建議使用這種方法的。
public List<Object> intersectionForList_3(List<Object> arr1, List<Object> arr2) {
List<Object> resultList = new ArrayList<>();
Map<String,Object> map = new HashMap<>();
arr1.forEach(a1->{
map.put(a1+"",a1);
});
arr2.forEach(a2->{
Object obj = map.get(a2 + "");
if (obj!=null){
resultList.add(obj);
}
});
return resultList;
}總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Java Spring框架簡(jiǎn)介與Spring IOC詳解
Spring 框架是一個(gè)輕量級(jí)的解決方案,可以一站式地構(gòu)建企業(yè)級(jí)應(yīng)用。它是為了解決 企業(yè)應(yīng)用開發(fā)的復(fù)雜性而創(chuàng)建的。Spring 使用基本的 JavaBean 來(lái)完成以前只可能由 EJB 完成的事情。IOC 是 Inversion of Control 的縮寫,多數(shù)書籍翻譯成控制反轉(zhuǎn)2021-09-09
tk.mybatis實(shí)現(xiàn)uuid主鍵生成的示例代碼
本文主要介紹了tk.mybatis實(shí)現(xiàn)uuid主鍵生成的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
String實(shí)例化及static final修飾符實(shí)現(xiàn)方法解析
這篇文章主要介紹了String實(shí)例化及static final修飾符實(shí)現(xiàn)方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09
APP轉(zhuǎn)盤抽獎(jiǎng)Java服務(wù)端接口詳解
這篇文章主要為大家詳細(xì)介紹了APP轉(zhuǎn)盤抽獎(jiǎng)Java服務(wù)端接口,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01

